

| Offset: 0x0200 |            |             | Register Name: PL_INT_CFG0                                                                                                                                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                 |
|                |            |             | Others: Reserved                                                                                                                                                            |
| 19:16          | R/W        | 0x0         | EINT4_CFG<br>External INT4 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge(Positive/Negative)<br>Others: Reserved |
| 15:12          | R/W        | 0x0         | EINT3_CFG<br>External INT3 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge(Positive/Negative)<br>Others: Reserved |
| 11:8           | R/W        | 0x0         | EINT2_CFG<br>External INT2 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge(Positive/Negative)<br>Others: Reserved |
| 7:4            | R/W        | 0x0         | EINT1_CFG<br>External INT1 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge(Positive/Negative)<br>Others: Reserved |
| 3:0            | R/W        | 0x0         | EINT0_CFG<br>External INT0 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge(Positive/Negative)<br>Others: Reserved |

## 8.5.7.24 0x0204 PL External Interrupt Configure Register 1 (Default Value: 0x0000\_0000)

| Offset: 0x0204 |            |             | Register Name: PL_INT_CFG1                                                                                                                                                    |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                   |
| 31:24          | /          | /           | /                                                                                                                                                                             |
| 23:20          | R/W        | 0x0         | EINT13_CFG<br>External INT13 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge(Positive/Negative)<br>Others: Reserved |
| 19:16          | R/W        | 0x0         | EINT12_CFG<br>External INT12 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge(Positive/Negative)<br>Others: Reserved |
| 15:12          | R/W        | 0x0         | EINT11_CFG<br>External INT11 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge(Positive/Negative)<br>Others: Reserved |
| 11:8           | R/W        | 0x0         | EINT10_CFG<br>External INT10 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge(Positive/Negative)<br>Others: Reserved |
| 7:4            | R/W        | 0x0         | EINT9_CFG<br>External INT9 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level                                                              |

| Offset: 0x0204 |            |             | Register Name: PL_INT_CFG1                                                                                                                                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                 |
|                |            |             | 0x4: Double Edge(Positive/Negative)<br>Others: Reserved                                                                                                                     |
| 3:0            | R/W        | 0x0         | EINT8_CFG<br>External INT8 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge(Positive/Negative)<br>Others: Reserved |

#### 8.5.7.25 0x0208 PL External Interrupt Configure Register 2 (Default Value: 0x0000\_0000)

| Offset: 0x0208 |            |             | Register Name: PL_INT_CFG2 |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:0           | /          | /           | /                          |

#### 8.5.7.26 0x020C PL External Interrupt Configure Register 3 (Default Value: 0x0000\_0000)

| Offset: 0x020C |            |             | Register Name: PL_INT_CFG3 |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:0           | /          | /           | /                          |

#### 8.5.7.27 0x0210 PL External Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0210 |            |             | Register Name: PL_INT_CTL                                      |
|----------------|------------|-------------|----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                    |
| 31:14          | /          | /           | /                                                              |
| 13             | R/W        | 0x0         | EINT13_CTL<br>External INT13 Enable<br>0: Disable<br>1: Enable |
| 12             | R/W        | 0x0         | EINT12_CTL<br>External INT12 Enable<br>0: Disable<br>1: Enable |
| 11             | R/W        | 0x0         | EINT11_CTL<br>External INT11 Enable<br>0: Disable              |

| Offset: 0x0210 |            |             | Register Name: PL_INT_CTL                                      |
|----------------|------------|-------------|----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                    |
|                |            |             | 1: Enable                                                      |
| 10             | R/W        | 0x0         | EINT10_CTL<br>External INT10 Enable<br>0: Disable<br>1: Enable |
| 9              | R/W        | 0x0         | EINT9_CTL<br>External INT9 Enable<br>0: Disable<br>1: Enable   |
| 8              | R/W        | 0x0         | EINT8_CTL<br>External INT8 Enable<br>0: Disable<br>1: Enable   |
| 7              | R/W        | 0x0         | EINT7_CTL<br>External INT7 Enable<br>0: Disable<br>1: Enable   |
| 6              | R/W        | 0x0         | EINT6_CTL<br>External INT6 Enable<br>0: Disable<br>1: Enable   |
| 5              | R/W        | 0x0         | EINT5_CTL<br>External INT5 Enable<br>0: Disable<br>1: Enable   |
| 4              | R/W        | 0x0         | EINT4_CTL<br>External INT4 Enable<br>0: Disable<br>1: Enable   |
| 3              | R/W        | 0x0         | EINT3_CTL<br>External INT3 Enable<br>0: Disable<br>1: Enable   |
| 2              | R/W        | 0x0         | EINT2_CTL<br>External INT2 Enable<br>0: Disable<br>1: Enable   |
| 1              | R/W        | 0x0         | EINT1_CTL<br>External INT1 Enable<br>0: Disable<br>1: Enable   |

| Offset: 0x0210 |            |             | Register Name: PL_INT_CTL                                    |
|----------------|------------|-------------|--------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                  |
| 0              | R/W        | 0x0         | EINT0_CTL<br>External INT0 Enable<br>0: Disable<br>1: Enable |

#### 8.5.7.28 0x0214 PL External Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0214 |            |             | Register Name: PL_INT_STA                                                                                |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                              |
| 31:14          | /          | /           | /                                                                                                        |
| 13             | R/W        | 0x0         | EINT13_STATUS<br>External INT13 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 12             | R/W        | 0x0         | EINT12_STATUS<br>External INT12 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 11             | R/W        | 0x0         | EINT11_STATUS<br>External INT11 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 10             | R/W        | 0x0         | EINT10_STATUS<br>External INT10 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 9              | R/W        | 0x0         | EINT9_STATUS<br>External INT9 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |
| 8              | R/W        | 0x0         | EINT8_STATUS<br>External INT8 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear   |
| 7              | R/W        | 0x0         | EINT7_STATUS                                                                                             |

| Offset: 0x0214 |            |             | Register Name: PL_INT_STA                                                                              |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                            |
|                |            |             | External INT7 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear                 |
| 6              | R/W        | 0x0         | EINT6_STATUS<br>External INT6 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 5              | R/W        | 0x0         | EINT5_STATUS<br>External INT5 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 4              | R/W        | 0x0         | EINT4_STATUS<br>External INT4 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 3              | R/W        | 0x0         | EINT3_STATUS<br>External INT3 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 2              | R/W        | 0x0         | EINT2_STATUS<br>External INT2 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 1              | R/W        | 0x0         | EINT1_STATUS<br>External INT1 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 0              | R/W        | 0x0         | EINT0_STATUS<br>External INT0 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |

## 8.5.7.29 0x0218 PL External Debounce Configure Register (Default Value: 0x0000\_0000)

| Offset: 0x0218 |            |             | Register Name: PL_INT_DEB                                                                          |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                        |
| 31:7           | /          | /           | /                                                                                                  |
| 6:4            | R/W        | 0x0         | DEB_CLK_PRE_SCALE<br>Debounce Clock Pre_scale n<br>The selected clock source is prescaled by $2^n$ |
| 3:1            | /          | /           | /                                                                                                  |
| 0              | R/W        | 0x0         | GPIO_INT_CLK_SELECT<br>GPIO Interrupt Clock Select<br>0: LOSC 32 kHz<br>1: HOSC 24 MHz             |

## 8.5.7.30 0x0220 PM External Interrupt Configure Register 0 (Default Value: 0x0000\_0000)

| Offset: 0x0220 |            |             | Register Name: PM_INT_CFG0                                                                                                                                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                 |
| 31:24          | /          | /           | /                                                                                                                                                                           |
| 23:20          | R/W        | 0x0         | EINT5_CFG<br>External INT5 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge(Positive/Negative)<br>Others: Reserved |
| 19:16          | R/W        | 0x0         | EINT4_CFG<br>External INT4 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge(Positive/Negative)<br>Others: Reserved |
| 15:12          | R/W        | 0x0         | EINT3_CFG<br>External INT3 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge(Positive/Negative)                     |

| Offset: 0x0220 |            |             | Register Name: PM_INT_CFG0                                                                                                                                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                 |
|                |            |             | Others: Reserved                                                                                                                                                            |
| 11:8           | R/W        | 0x0         | EINT2_CFG<br>External INT2 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge(Positive/Negative)<br>Others: Reserved |
| 7:4            | R/W        | 0x0         | EINT1_CFG<br>External INT1 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge(Positive/Negative)<br>Others: Reserved |
| 3:0            | R/W        | 0x0         | EINT0_CFG<br>External INT0 Mode<br>0x0: Positive Edge<br>0x1: Negative Edge<br>0x2: High Level<br>0x3: Low Level<br>0x4: Double Edge(Positive/Negative)<br>Others: Reserved |

#### 8.5.7.31 0x0224 PM External Interrupt Configure Register 1 (Default Value: 0x0000\_0000)

| Offset: 0x0224 |            |             | Register Name: PM_INT_CFG1 |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:0           | /          | /           | /                          |

#### 8.5.7.32 0x0228 PM External Interrupt Configure Register 2 (Default Value: 0x0000\_0000)

| Offset: 0x0228 |            |             | Register Name: PM_INT_CFG2 |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:0           | /          | /           | /                          |

## 8.5.7.33 0x022C PM External Interrupt Configure Register 3 (Default Value: 0x0000\_0000)

| Offset: 0x022C |            |             | Register Name: PM_INT_CFG3 |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:0           | /          | /           | /                          |

## 8.5.7.34 0x0230 PM External Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0230 |            |             | Register Name: PM_INT_CTL                                    |
|----------------|------------|-------------|--------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                  |
| 31:6           | /          | /           | /                                                            |
| 5              | R/W        | 0x0         | EINT5_CTL<br>External INT5 Enable<br>0: Disable<br>1: Enable |
| 4              | R/W        | 0x0         | EINT4_CTL<br>External INT4 Enable<br>0: Disable<br>1: Enable |
| 3              | R/W        | 0x0         | EINT3_CTL<br>External INT3 Enable<br>0: Disable<br>1: Enable |
| 2              | R/W        | 0x0         | EINT2_CTL<br>External INT2 Enable<br>0: Disable<br>1: Enable |
| 1              | R/W        | 0x0         | EINT1_CTL<br>External INT1 Enable<br>0: Disable<br>1: Enable |
| 0              | R/W        | 0x0         | EINT0_CTL<br>External INT0 Enable<br>0: Disable<br>1: Enable |

## 8.5.7.35 0x0234 PM External Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0234 |            |             | Register Name: PM_INT_STA |
|----------------|------------|-------------|---------------------------|
| Bit            | Read/Write | Default/Hex | Description               |
| 31:6           | /          | /           | /                         |
| 5              | R/W        | 0x0         | EINT5_STATUS              |

| Offset: 0x0234 |            |             | Register Name: PM_INT_STA                                                                              |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                            |
|                |            |             | External INT5 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear                 |
| 4              | R/W        | 0x0         | EINT4_STATUS<br>External INT4 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 3              | R/W        | 0x0         | EINT3_STATUS<br>External INT3 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 2              | R/W        | 0x0         | EINT2_STATUS<br>External INT2 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 1              | R/W        | 0x0         | EINT1_STATUS<br>External INT1 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |
| 0              | R/W        | 0x0         | EINT0_STATUS<br>External INT0 Pending Bit<br>0: No IRQ pending<br>1: IRQ pending<br>Write '1' to clear |

#### 8.5.7.36 0x0238 PM External Debounce Configure Register (Default Value: 0x0000\_0000)

| Offset: 0x0238 |            |             | Register Name: PM_INT_DEB                                                                          |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                        |
| 31:7           | /          | /           | /                                                                                                  |
| 6:4            | R/W        | 0x0         | DEB_CLK_PRE_SCALE<br>Debounce Clock Pre_scale n<br>The selected clock source is prescaled by $2^n$ |
| 3:1            | /          | /           | /                                                                                                  |
| 0              | R/W        | 0x0         | GPIO_INT_CLK_SELECT                                                                                |

| Offset: 0x0238 |            |             | Register Name: PM_INT_DEB                                       |
|----------------|------------|-------------|-----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                     |
|                |            |             | GPIO Interrupt Clock Select<br>0: LOSC 32 kHz<br>1: HOSC 24 MHz |

#### 8.5.7.37 0x0340 GPIO Group Withstand Voltage Mode Select Register (Default Value: 0x0000\_0003)

| Offset: 0x0340 |            |             | Register Name: GPIO_POW_MOD_SEL                                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                |
| 31:13          | /          | /           | /                                                                                                                          |
| 12             | R/W        | 0x0         | VCCIO_PWR_MOD_SEL<br>VCC-IO POWER MODE Select<br>1: 3.3V<br>0: 1.8V                                                        |
| 11:2           | /          | /           | /                                                                                                                          |
| 1              | R/W        | 0x1         | PM_PWR_MOD_SEL<br>PM_POWER MODE Select<br>1: 3.3V<br>0: 1.8V<br>If PM_Port Power Source select VCC-IO, this bit is invalid |
| 0              | R/W        | 0x1         | PL_PWR_MOD_SEL<br>PL_POWER MODE Select<br>1: 3.3V<br>0: 1.8V<br>If PL_Port Power Source select VCC_IO, this bit is invalid |

#### 8.5.7.38 0x0344 GPIO Group Withstand Voltage Mode Select Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0344 |            |             | Register Name: GPIO_POW_MS_CTL                                                                  |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                     |
| 31:13          | /          | /           | /                                                                                               |
| 12             | R/W        | 0x0         | VCCIO_WS_VOL_MOD_SEL<br>VCC_IO Withstand Voltage Mode Select Control<br>0: Enable<br>1: Disable |
| 11:2           | /          | /           | /                                                                                               |
| 1              | R/W        | 0x0         | VCC_PM_WS_VOL_MOD_SEL                                                                           |

| Offset: 0x0344 |            |             | Register Name: GPIO_POW_MS_CTL                                                                   |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                      |
|                |            |             | VCC_PM Withstand Voltage Mode Select Control<br>0: Enable<br>1: Disable                          |
| 0              | R/W        | 0x0         | VCC_PL_WS_VOL_MOD_SEL<br>VCC_PL Withstand Voltage Mode Select Control<br>0: Enable<br>1: Disable |

#### 8.5.7.39 0x0348 GPIO Group Power Value Register (Default Value: 0x0000\_0000)

| Offset: 0x0348 |            |             | Register Name: GPIO_POW_VAL                                                                     |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                     |
| 31:17          | /          | /           | /                                                                                               |
| 16             | R          | 0x0         | VCCIO_PWR_VAL<br>VCC_IO Power Value                                                             |
| 15:2           | /          | /           | /                                                                                               |
| 1              | R          | 0x0         | PM_PWR_VAL<br>PM_Port Power Value<br>If PM_Port Power Source select VCC_IO, this bit is invalid |
| 0              | R          | 0x0         | PL_PWR_VAL<br>PL_Port Power Value<br>If PL_Port Power Source select VCC_IO, this bit is invalid |

#### 8.5.7.40 0x0350 GPIO Group Power Voltage Select Control Register (Default Value: 0x0000\_0001)

| Offset: 0x0350 |            |             | Register Name: GPIO_POW_VAL_SET_CTL                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                     |
| 31:1           | /          | /           | /                                                                               |
| 0              | R/W        | 0x1         | VCC_PF_PWR_VOL_SEL<br>VCC_PF Power Voltage Select Control<br>0: 1.8V<br>1: 3.3V |

## 8.6 LEDC

### 8.6.1 Overview

The LEDC is used to control the external LED lamp.

The LEDC has the following features:

- Configurable LED output high-/low-level width
- Configurable LED reset time
- Configurable interval time for packets and frame data
- LEDC data supports DMA configuration mode and CPU configuration mode
- Maximum 1024 LEDs serial connect
- LED data transfer rate up to 800 kbit/s
- Configurable RGB display mode

### 8.6.2 Block Diagram

The following figure shows a block diagram of the LEDC.

Figure 8-24 LEDC Block Diagram



LEDC contains the following sub-blocks:

Table 8-22 LEDC Sub-blocks

| Sub-block  | Description                                         |
|------------|-----------------------------------------------------|
| config     | register configuration                              |
| control    | LEDC timing control and status control              |
| FIFO       | 24-bit width x 32 depth                             |
| Data_trans | Convert input data to the 0 and 1 characters of LED |

### 8.6.3 Functional Description

#### 8.6.3.1 External Signals

The following table describes the external signals of the LEDC.

**Table 8-23 LEDC External Signals**

| Signal Name | Description                           | Type |
|-------------|---------------------------------------|------|
| LEDC        | Intelligent Control LED Signal Output | O    |

#### 8.6.3.2 Clock Sources

The following table describes the clock sources of the LEDC.

**Table 8-24 LEDC Clock Sources**

| Clock Sources | Description                                    | module |
|---------------|------------------------------------------------|--------|
| HOSC          | 24 MHz                                         |        |
| PERI0_600M    | Peripheral Clock. The default value is 600 MHz | CCU    |

#### 8.6.3.3 Reset

The following table describes the reset of the LEDC.

**Table 8-25 LEDC Reset**

| Reset signal | Source |
|--------------|--------|
| LEDC_RST     | CCU    |

#### 8.6.3.4 LEDC Timing

**Figure 8-25 LEDC Package Output Timing Diagram**



Figure 8-26 LEDC 1-frame Output Timing Diagram



#### 8.6.3.5 LEDC Input Data Structure

The RGB mode of LEDC data is configurable. By default, the data is sent in GRB order, and the higher bit is transmitted first.

Figure 8-27 LEDC Input Data Structure

|    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| G7 | G6 | G5 | G4 | G3 | G2 | G1 | G0 | R7 | R6 | R5 | R4 | R3 | R2 | R1 | R0 | B7 | B6 | B5 | B4 | B3 | B2 | B1 | B0 |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|

#### 8.6.3.6 LEDC Typical Circuit

Figure 8-28 LEDC Typical Circuit



C1 is the filter capacitor of LED light, and its value is usually 100 Nf.

### 8.6.3.7 LEDC Data Input Code

Figure 8-29 LEDC Data Input Code



### 8.6.3.8 LEDC Data Transfer Time

The time parameter of the typical LED specification shows as follows.

Table 8-26 Time Parameters of Typical LED Specification

|       |                            |                  |
|-------|----------------------------|------------------|
| T0H   | 0 code, high-level time    | 220 ns to 380 ns |
| T0L   | 0 code, low-level time     | 580 ns to 1.6 us |
| T1H   | 1 code, high-level time    | 580 ns to 1.6 us |
| T1L   | 1 code, low-level time     | 220 ns to 420 ns |
| RESET | Frame unit, low-level time | > 280 us         |

### 8.6.3.9 LEDC Data Transfer Mode

Figure 8-30 LEDC Data Transfer Mode



### 8.6.3.10 LEDC Parameter

- PAD rate > 800 kbit/s
- LED number supported:  $T_{0\text{-code}}$ : 800 ns to 1980 ns,  $T_{1\text{-code}}$ : 800 ns to 2020 ns

When the LED refresh rate is 30 frame/s, LED number supported is  $(1 \text{ s}/30-280 \text{ us}) / ((800 \text{ ns} \text{ to } 2020 \text{ ns}) * 24) = 1023 \text{ to } 681$ .

When the LED refresh rate is 60 frame/s, LED number supported is  $(1 \text{ s}/60-280 \text{ us}) / ((800 \text{ ns} \text{ to } 2020 \text{ ns}) * 24) = 853 \text{ to } 337$ .

### 8.6.3.11 LEDC Data Transfer

The LEDC supports DMA data transfer mode or CPU data transfer mode. The DMA data transfer mode is set by LEDC\_DMA\_EN

- Data transfer in DMA mode

When the valid space of internal FIFO is greater than the setting FIFO free space threshold, the LEDC sends DMA\_REQ to require DMA to transfer data from DRAM to LEDC. The maximum data transfer size in DMA mode is 16 words. (The internal FIFO level is 32.)

- Data transfer in CPU mode

When the valid space of internal FIFO is greater than the setting FIFO free space threshold, the LEDC sends LEDC\_CPUREQ\_INT to require CPU to transfer data to LEDC. The transfer data size in CPU mode is controlled by software. The internal FIFO destination address is 0x06700014. The data width is 32-bit. (The lower 24-bit is valid.)

### 8.6.3.12 LEDC Interrupt

| Module Name           | Description                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FIFO_OVERFLOW_INT     | FIFO overflow interrupt.<br>The data written by external is more than the maximum storage space of LED FIFO, the LEDC will be in data loss state. At this time, software needs to deal with the abnormal situation. The processing mode is as follows.<br>The software can query LED_FIFO_DATA_REG to determine which data has been stored in the internal FIFO of LEDC. The LEDC performs soft_reset operation to refresh all data. |
| FIFO_CPUREQ_INT       | FIFO request CPU data interrupt<br>When FIFO data is less than a threshold, the interrupt will be reported to the CPU.                                                                                                                                                                                                                                                                                                               |
| LEDC_TRANS_FINISH_INT | Data transfer complete interrupt<br>The value indicates that the data configured as total_data_length has been transferred completely.                                                                                                                                                                                                                                                                                               |

LEDC interrupt usage scenario:

- CPU mode

The software can enable GLOBAL\_INT\_EN, FIFO\_CPUREQ\_INT\_EN, WAITDATA\_TIMEOUT\_INT\_EN, FIFO\_OVERFLOW\_INT\_EN, LEDC\_TRANS\_FINISH\_INT\_EN, and cooperate with LEDC\_FIFO\_TRIG\_LEVEL to use. When FIFO\_CPUREQ\_INT is set to 1, the software can configure data of LEDC\_FIFO\_TRIG\_LEVEL to LEDC.

- DMA mode

The software can enable GLOBAL\_INT\_EN, WAITDATA\_TIMEOUT\_INT\_EN, FIFO\_OVERFLOW\_INT\_EN, LEDC\_TRANS\_FINISH\_INT\_EN, and cooperate with

LEDC\_FIFO\_TRIG\_LEVEL to use. When DMA receives LEDC DMA\_REQ, DMA can transfer data of LEDC\_FIFO\_TRIG\_LEVEL to LEDC.

## 8.6.4 Programming Guidelines

### 8.6.4.1 LEDC Normal Configuration Process

**Step 1** Configure LEDC\_CLK and bus pclk.

**Step 2** Configure the written LEDC data.

**Step 3** Configure [LED\\_T01\\_TIMING\\_CTRL\\_REG](#), [LEDC\\_DATA\\_FINISH\\_CNT\\_REG](#), [LED\\_RESET\\_TIMING\\_CTRL\\_REG](#), [LEDC\\_WAIT\\_TIME0\\_CTRL\\_REG](#), [LEDC\\_DMA\\_CTRL\\_REG](#), [LEDC\\_INTERRUPT\\_CTRL\\_REG](#). Configure 0-code, 1-code, reset time, LEDC waiting time, and the number of external connected LEDC and the threshold of DMA transfer data.

**Step 4** Configure [LEDC\\_CTRL\\_REG](#) to enable LEDC\_EN, the LEDC will start to output data.

**Step 5** When the LEDC interrupt is pulled up, it indicates the configured data has transferred complete, at this time LED\_EN will be set to 0, and the read/write point of LEDC FIFO is cleared to 0.

**Step 6** Repeat step1, 2, 3, 4 to re-execute a new round of configuration, enable LEDC\_EN, the LEDC will start new data transfer.

Figure 8-31 LEDC Normal Configuration Process



#### 8.6.4.2 LEDC Abnormal Scene Processing Flow

##### WAITDATA\_TIMEOUT Abnormal Status

- Step 1** When WAITDATA\_TIMEOUT\_INT appears, it indicates the internal FIFO data request of LEDC cannot obtain a response, at this time if the default output level is low, then the external LED may think there was a reset operation and cause LED data to be flushed incorrectly.
- Step 2** The LEDC needs to be performed soft\_reset operation (LEDC\_SOFT\_RESET=1); after soft\_reset, the LEDC\_EN will be pulled-down automatically, all internal status register and control state machine will return to the idle state, the LEDC FIFO read & write point is cleared to 0, the LEDC interrupt is cleared.
- Step 3** Setting reset\_led\_en to 1 indicates LEDC can actively send a reset operation to ensure the external LED lamp in the right state.

**Step 4** The software reads the status of reset\_led\_en, when the status value is 1, it indicates LEDC does not perform the transmission of LED reset operation; when the status value is 0, the LEDC completes the transmission of LED reset operation.

**Step 5** When LEDC reset operation finishes, the LEDC data and register configuration need to be re-operated to start re-transmission data operation.

Figure 8-32 LEDC Timeout Abnormal Processing Flow



### FIFO Overflow Abnormal Status

- Step 1** When FIFO\_OVERFLOW\_INT appears, it indicates the data configured by software exceeds the LEDC FIFO space, at this time the redundant data will be lost.
- Step 2** The software needs to read data in [LED\\_C\\_FIFO\\_DATA\\_X](#) to confirm the lost data.
- Step 3** The software re-configures the lost data to the LEDC.
- Step 4** If the software uses the soft\_reset operation, the operation is the same with the timeout abnormal processing flow.



**Figure 8-33 FIFO Overflow Abnormal Processing Flow**

### 8.6.5 Register List

| Module Name | Base Address |
|-------------|--------------|
| LEDC        | 0x02008000   |

| Register Name             | Offset            | Description                          |
|---------------------------|-------------------|--------------------------------------|
| LEDC_CTRL_REG             | 0x0000            | LEDC Control Register                |
| LED_T01_TIMING_CTRL_REG   | 0x0004            | LEDC T0 & T1 Timing Control Register |
| LEDC_DATA_FINISH_CNT_REG  | 0x0008            | LEDC Data Finish Counter Register    |
| LED_RESET_TIMING_CTRL_REG | 0x000C            | LEDC Reset Timing Control Register   |
| LEDC_WAIT_TIME0_CTRL_REG  | 0x0010            | LEDC Wait Time0 Control Register     |
| LEDC_DATA_REG             | 0x0014            | LEDC Data Register                   |
| LEDC_DMA_CTRL_REG         | 0x0018            | LEDC DMA Control Register            |
| LEDC_INT_CTRL_REG         | 0x001C            | LEDC Interrupt Control Register      |
| LEDC_INT_STS_REG          | 0x0020            | LEDC Interrupt Status Register       |
| LEDC_WAIT_TIME1_CTRL_REG  | 0x0028            | LEDC Wait Time1 Control Register     |
| LEDC_FIFO_DATA_REG        | 0x0030+0x04<br>*N | LEDC FIFO Data Register              |

## 8.6.6 Register Description

### 8.6.6.1 0x0000 LEDC Control Register (Default Value: 0x0000\_003C)

| Offset: 0x0000 |            |             | Register Name: LEDC_CTRL_REG                                                                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                           |
| 31:29          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                     |
| 28:16          | R/W        | 0x0         | TOTAL_DATA_LENGTH<br>Total length of transfer data (range: 0 to 8K, unit: 32-bit, only low 24-bit is valid)<br>The field is recommended to be set to an integer multiple of (LED_NUM+1).<br>If TOTAL_DATA_LENGTH is greater than (LED_NUM+1), but non-integer multiple, the last frame of data will transfer data less than (LED_NUM+1).              |
| 15:11          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                     |
| 10             | R/WAC      | 0x0         | RESET_LED_EN<br>Write operation:<br>The software writes 1 to the bit, the CPU triggers LEDC to transfer a reset to LED.<br>Only when LEDC is in IDLE status, the reset can be performed. After the reset finished, the control state machine returns to the IDLE status. To return LEDC to the IDLE status, it also needs to be used with SOFT_RESET. |

| Offset: 0x0000      |               |                  | Register Name: LEDC_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |     |              |     |     |     |     |     |     |     |     |     |     |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|---------------------|---------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|---------------------|---------------|------------------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Bit                 | Read/Write    | Default/Hex      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |     |              |     |     |     |     |     |     |     |     |     |     |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                     |               |                  | <p>When the software sets the bit, the software can read the bit to check if the reset is complete.</p> <p>Read operation:</p> <ul style="list-style-type: none"> <li>0: LEDC completes the transmission of the LED reset operation</li> <li>1: LEDC does not complete the transmission of the LED reset operation</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |     |              |     |     |     |     |     |     |     |     |     |     |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| 9                   | /             | /                | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |     |              |     |     |     |     |     |     |     |     |     |     |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| 8:6                 | R/W           | 0x0              | <p>LED_RGB_MODE</p> <table> <tr><td>000</td><td>GRB (bypass)</td></tr> <tr><td>001</td><td>GBR</td></tr> <tr><td>010</td><td>RGB</td></tr> <tr><td>011</td><td>RBG</td></tr> <tr><td>100</td><td>BGR</td></tr> <tr><td>101</td><td>BRG</td></tr> </table> <p>By default, the software configures data to LEDC according to GRB (MSB) mode, the LEDC internal combines data to output to the external LED.</p> <p>Other modes configure as follows.</p> <table> <thead> <tr> <th>Software Input Mode</th><th>Configuration</th><th>LEDC Output Mode</th></tr> </thead> <tbody> <tr> <td rowspan="6">GRB</td><td>000</td><td>GRB</td></tr> <tr> <td>001</td><td>GBR</td></tr> <tr> <td>010</td><td>RGB</td></tr> <tr> <td>011</td><td>RBG</td></tr> <tr> <td>100</td><td>BGR</td></tr> <tr> <td>101</td><td>BRG</td></tr> <tr> <td rowspan="6">GBR</td><td>000</td><td>GBR</td></tr> <tr> <td>001</td><td>GRB</td></tr> <tr> <td>010</td><td>BGR</td></tr> <tr> <td>011</td><td>BRG</td></tr> <tr> <td>100</td><td>RGB</td></tr> <tr> <td>101</td><td>RBG</td></tr> <tr> <td rowspan="6">RGB</td><td>000</td><td>RGB</td></tr> <tr> <td>001</td><td>RBG</td></tr> <tr> <td>010</td><td>GRB</td></tr> <tr> <td>011</td><td>GBR</td></tr> <tr> <td>100</td><td>BRG</td></tr> <tr> <td>101</td><td>BGR</td></tr> <tr> <td>RBG</td><td>000</td><td>RBG</td></tr> </tbody> </table> | 000 | GRB (bypass) | 001 | GBR | 010 | RGB | 011 | RBG | 100 | BGR | 101 | BRG | Software Input Mode | Configuration | LEDC Output Mode | GRB | 000 | GRB | 001 | GBR | 010 | RGB | 011 | RBG | 100 | BGR | 101 | BRG | GBR | 000 | GBR | 001 | GRB | 010 | BGR | 011 | BRG | 100 | RGB | 101 | RBG | RGB | 000 | RGB | 001 | RBG | 010 | GRB | 011 | GBR | 100 | BRG | 101 | BGR | RBG | 000 | RBG |
| 000                 | GRB (bypass)  |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |              |     |     |     |     |     |     |     |     |     |     |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| 001                 | GBR           |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |              |     |     |     |     |     |     |     |     |     |     |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| 010                 | RGB           |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |              |     |     |     |     |     |     |     |     |     |     |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| 011                 | RBG           |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |              |     |     |     |     |     |     |     |     |     |     |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| 100                 | BGR           |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |              |     |     |     |     |     |     |     |     |     |     |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| 101                 | BRG           |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |              |     |     |     |     |     |     |     |     |     |     |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| Software Input Mode | Configuration | LEDC Output Mode |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |              |     |     |     |     |     |     |     |     |     |     |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| GRB                 | 000           | GRB              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |              |     |     |     |     |     |     |     |     |     |     |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                     | 001           | GBR              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |              |     |     |     |     |     |     |     |     |     |     |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                     | 010           | RGB              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |              |     |     |     |     |     |     |     |     |     |     |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                     | 011           | RBG              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |              |     |     |     |     |     |     |     |     |     |     |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                     | 100           | BGR              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |              |     |     |     |     |     |     |     |     |     |     |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                     | 101           | BRG              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |              |     |     |     |     |     |     |     |     |     |     |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| GBR                 | 000           | GBR              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |              |     |     |     |     |     |     |     |     |     |     |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                     | 001           | GRB              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |              |     |     |     |     |     |     |     |     |     |     |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                     | 010           | BGR              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |              |     |     |     |     |     |     |     |     |     |     |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                     | 011           | BRG              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |              |     |     |     |     |     |     |     |     |     |     |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                     | 100           | RGB              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |              |     |     |     |     |     |     |     |     |     |     |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                     | 101           | RBG              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |              |     |     |     |     |     |     |     |     |     |     |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| RGB                 | 000           | RGB              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |              |     |     |     |     |     |     |     |     |     |     |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                     | 001           | RBG              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |              |     |     |     |     |     |     |     |     |     |     |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                     | 010           | GRB              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |              |     |     |     |     |     |     |     |     |     |     |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                     | 011           | GBR              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |              |     |     |     |     |     |     |     |     |     |     |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                     | 100           | BRG              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |              |     |     |     |     |     |     |     |     |     |     |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
|                     | 101           | BGR              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |              |     |     |     |     |     |     |     |     |     |     |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |
| RBG                 | 000           | RBG              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |     |              |     |     |     |     |     |     |     |     |     |     |                     |               |                  |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |     |

| Offset: 0x0000 |            |             | Register Name: LEDC_CTRL_REG                                                                                                                                                                                                                                                                                                                          |     |  |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                           |     |  |
|                |            |             | 001                                                                                                                                                                                                                                                                                                                                                   | RGB |  |
|                |            |             | 010                                                                                                                                                                                                                                                                                                                                                   | BRG |  |
|                |            |             | 011                                                                                                                                                                                                                                                                                                                                                   | BGR |  |
|                |            |             | 100                                                                                                                                                                                                                                                                                                                                                   | GRB |  |
|                |            |             | 101                                                                                                                                                                                                                                                                                                                                                   | GBR |  |
|                |            |             | 000                                                                                                                                                                                                                                                                                                                                                   | BGR |  |
|                |            |             | 001                                                                                                                                                                                                                                                                                                                                                   | BRG |  |
|                |            |             | 010                                                                                                                                                                                                                                                                                                                                                   | GBR |  |
|                |            |             | 011                                                                                                                                                                                                                                                                                                                                                   | GRB |  |
|                |            |             | 100                                                                                                                                                                                                                                                                                                                                                   | RBG |  |
|                |            |             | 101                                                                                                                                                                                                                                                                                                                                                   | RGB |  |
|                |            |             | 000                                                                                                                                                                                                                                                                                                                                                   | BRG |  |
|                |            |             | 001                                                                                                                                                                                                                                                                                                                                                   | BGR |  |
|                |            |             | 010                                                                                                                                                                                                                                                                                                                                                   | RBG |  |
|                |            |             | 011                                                                                                                                                                                                                                                                                                                                                   | RGB |  |
|                |            |             | 100                                                                                                                                                                                                                                                                                                                                                   | GBR |  |
|                |            |             | 101                                                                                                                                                                                                                                                                                                                                                   | GRB |  |
| 5              | R/W        | 0x1         | LED_MSB_TOP<br>Adjust sequence of the combined GRB data<br>0: LSB<br>1: MSB                                                                                                                                                                                                                                                                           |     |  |
| 4              | R/W        | 0x1         | LED_MSB_G<br>MSB control for Green data<br>0: LSB<br>1: MSB                                                                                                                                                                                                                                                                                           |     |  |
| 3              | R/W        | 0x1         | LED_MSB_R<br>MSB control for Red data<br>0: LSB<br>1: MSB                                                                                                                                                                                                                                                                                             |     |  |
| 2              | R/W        | 0x1         | LED_MSB_B<br>MSB control for Blue data<br>0: LSB<br>1: MSB                                                                                                                                                                                                                                                                                            |     |  |
| 1              | R/W1C      | 0x0         | LEDC_SOFT_RESET<br>LEDC soft reset<br>Write 1 to clear it automatically.<br>The ranges of LEDC soft reset include the following points: all internal status registers, the control state machine returns to in idle status, the LEDC FIFO read & write point is cleared to 0, the LEDC interrupt is cleared; and the affected registers are followed. |     |  |

| Offset: 0x0000 |            |             | Register Name: LEDC_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                |            |             | 1.LEDC_CTRL_REG (LEDC_EN is cleared to 0);<br>2. PLL_T0&1_TIMING_CTRL_REG remains unchanged;<br>3. LEDC_DATA_FINISH_CNT_REG (LEDC_DATA_FINISH_CNT is cleared to 0);<br>4.LED_RESET_TIMING_CTRL_REG remains unchanged;<br>5. LEDC_WAIT_TIME_CTRL_REG remains unchanged;<br>6. LEDC_DMA_CTRL_REG remains unchanged;<br>7. LEDC_INTERRUPT_CTRL_REG remains unchanged;<br>8.LEDC_INT_STS_REG is cleared to 0;<br>9. LEDC_CLK_GATING_REG remains unchanged;<br>10.LEDC_FIFO_DATA_REG remains unchanged; |
| 0              | R/W        | 0x0         | <b>LEDC_EN</b><br>LEDC Enable<br>0: Disable<br>1: Enable<br>That the bit is enabled indicates LEDC can be started when LEDC data finished transmission or LEDC_EN is cleared to 0 by hardware in LEDC_SOFT_RESET situation.                                                                                                                                                                                                                                                                        |

#### 8.6.6.2 0x0004 LEDC T0 & T1 Timing Control Register (Default Value: 0x0286\_01D3)

| Offset: 0x0004 |            |             | Register Name: LED_T01_TIMING_CTRL_REG                                                                                                                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                     |
| 31:27          | /          | /           | /                                                                                                                                                                               |
| 26:21          | R/W        | 0x14        | <b>T1H_TIME</b><br>LED T1H time<br>Unit: cycle (24 MHz), t1h_time =42 ns*(N+1)<br>The default value is 882 ns, the range is 80 ns–2560 ns.<br>N: 1–3F. When is 0, t1h_time = 3F |
| 20:16          | R/W        | 0x6         | <b>T1L_TIME</b><br>LED T1L time<br>Unit: cycle (24 MHz), t1l_time =42 ns*(N+1)<br>The default value is 294 ns, the range is 80 ns–1280 ns.<br>N: 1–1F. When is 0, t1l_time = 1F |
| 15:11          | /          | /           | /                                                                                                                                                                               |

| Offset: 0x0004 |            |             | Register Name: LED_T01_TIMING_CTRL_REG                                                                                                                                    |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                               |
| 10:6           | R/W        | 0x7         | T0H_TIME<br>LED T0h time<br>Unit: cycle (24 MHz), t0h_time = 42 ns*(N+1)<br>The default value is 336 ns, the range is 80 ns–1280 ns.<br>N: 1–1F. When is 0, t0h_time = 1F |
| 5:0            | R/W        | 0x13        | T0L_TIME<br>LED T0l time<br>Unit: cycle (24 MHz), t0L_time = 42 ns*(N+1)<br>The default value is 840 ns, the range is 80 ns–2560 ns.<br>N: 1–3F. When is 0, t0L_time = 3F |

#### 8.6.6.3 0x0008 LEDC Data Finish Counter Register (Default Value: 0x1D4C\_0000)

| Offset: 0x0008 |            |             | Register Name: LEDC_DATA_FINISH_CNT_REG                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 31:30          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 29:16          | R/W        | 0x1D4C      | LED_WAIT_DATA_TIME<br>The value is the time that internal FIFO in LEDC is waiting for data. When the time is exceeded, the LEDC will send the wait_data_timeout_int interrupt. (This is an abnormal situation, software needs to reset LEDC.)<br>The value is about 300 us by default.<br>The adjust range is 80 ns–655 us.<br>led_wait_data_time=42ns*(N+1).<br>N: 1–1FFF. When the field is 0,<br>LEDC_WAIT_DATA_TIME=1FFF |
| 15:13          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 12:0           | R          | 0x0         | LED_DATA_FINISH_CNT<br>The value is the total LED data that have been sent.<br>(Range: 0–8k)                                                                                                                                                                                                                                                                                                                                 |

#### 8.6.6.4 0x000C LEDC Reset Timing Control Register (Default Value: 0x1D4C\_0000)

| Offset: 0x000C |            |             | Register Name: LED_RESET_TIMING_CTRL_REG |
|----------------|------------|-------------|------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                              |
| 31:29          | /          | /           | /                                        |
| 28:16          | R/W        | 0x1D4C      | TR_TIME                                  |

| Offset: 0x000C |            |             | Register Name: LED_RESET_TIMING_CTRL_REG                                                                                                                                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                       |
|                |            |             | Reset time control of LED lamp<br>Unit: cycle (24 MHz), tr_time=42 ns*(N+1)<br>The default value is 300 us.<br>The adjust range is 80 ns–327 us.<br>N: 1–1FFF<br>If the value is 0, TR_TIME=1FFF. |
| 15:10          | /          | /           | /                                                                                                                                                                                                 |
| 9:0            | R/W        | 0x0         | LED_NUM<br>The value is the number of external LED lamp.<br>Maximum up to 1024.<br>The default value 0 indicates that 1 LED lamp is external connected. The range is from 0 to 1023.              |

#### 8.6.6.5 0x0010 LEDC Wait Time 0 Control Register (Default Value: 0x0000\_00FF)

| Offset: 0x0010 |            |             | Register Name: LEDC_WAIT_TIME0_CTRL_REG                                                                                                                                            |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                        |
| 31:9           | /          | /           | /                                                                                                                                                                                  |
| 8              | R/W        | 0x0         | WAIT_TIM0_EN<br>WAIT_TIME0 enable<br>When it is 1, the controller automatically inserts waiting time between LED package data.<br>0: Disable<br>1: Enable                          |
| 7:0            | R/W        | 0xFF        | TOTAL_WAIT_TIME0<br>Waiting time between 2 LED data. The LEDC output is low level.<br>The adjust range is 80 ns–10 us.<br>wait_time0=42 ns*(N+1)<br>Unit: cycle(24 MHz)<br>N: 1–FF |

#### 8.6.6.6 0x0014 LEDC Data Register (Default Value: 0x0000\_0000)

| Offset: 0x0014 |            |             | Register Name: LEDC_DATA_REG                              |
|----------------|------------|-------------|-----------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                               |
| 31:0           | W          | 0x0         | LEDC DATA<br>LED display data (the lower 24-bit is valid) |

### 8.6.6.7 0x0018 LEDC DMA Control Register (Default Value: 0x0000\_002F)

| Offset: 0x0018 |            |             | Register Name: LEDC_DMA_CTRL_REG                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                |
| 31:6           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 5              | R/W        | 0x1         | LEDC_DMA_EN<br>LEDC DMA request enable<br>0: Disable request of DMA transfer data<br>1: Enable request of DMA transfer data                                                                                                                                                                                                                                                                                                |
| 4:0            | R/W        | 0x0F        | LEDC_FIFO_TRIG_LEVEL<br>The remaining space of internal FIFO in LEDC<br>The internal FIFO in LEDC is 24*32.<br>When the remaining space of internal FIFO in LEDC is more than or equal to LEDFIFO_TRIG_LEVEL, the DMA or the CPU request will generate. The default value is 15.<br>The adjusted value is from 1 to 31. The recommended configuration is 7 or 15. When the configuration value is 0, LEDFIFO_TRIG_LEVEL=F. |

### 8.6.6.8 0x001C LEDC Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x001C |            |             | Register Name: LEDC_INTERRUPT_CTRL_REG                                                                                                                                                                       |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                  |
| 31:6           | /          | /           | /                                                                                                                                                                                                            |
| 5              | R/W        | 0x0         | GLOBAL_INT_EN<br>Global interrupt enable<br>0: Disable<br>1: Enable                                                                                                                                          |
| 4              | R/W        | 0x0         | FIFO_OVERFLOW_INT_EN<br>FIFO overflow interrupt enable<br>When the data written by the software is more than the internal FIFO level of LEDC, the LEDC is in the data loss state.<br>0: Disable<br>1: Enable |
| 3              | R/W        | 0x0         | WAITDATA_TIMEOUT_INT_EN<br>The internal FIFO in LEDC cannot get data because of some abnormal situation, after the time of led_wait_data_time, the interrupt will be enabled.<br>0: Disable<br>1: Enable     |
| 2              | /          | /           | /                                                                                                                                                                                                            |

| Offset: 0x001C |            |             | Register Name: LEDC_INTERRUPT_CTRL_REG                                                            |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                       |
| 1              | R/W        | 0x0         | FIFO_CPUREQ_INT_EN<br>FIFO request CPU data interrupt enable<br>0: Disable<br>1: Enable           |
| 0              | R/W        | 0x0         | LED_TRANS_FINISH_INT_EN<br>Data transmission complete interrupt enable<br>0: Disable<br>1: Enable |

#### 8.6.6.9 0x0020 LEDC Interrupt Status Register (Default Value: 0x0002\_0000)

| Offset: 0x0020 |            |             | Register Name: LEDC_INT_STS_REG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 31:18          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 17             | R          | 0x1         | FIFO_EMPTY<br>FIFO empty status flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 16             | R          | 0x0         | FIFO_FULL<br>FIFO full status flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 15:10          | R          | 0x0         | FIFO_WLW<br>FIFO internal valid data depth<br>It indicates the space FIFO has been occupied.                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 9:5            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 4              | R/W1C      | 0x0         | FIFO_OVERFLOW_INT<br>FIFO overflow interrupt<br>The data written by external is more than the maximum storage space of LED FIFO, the LEDC will be in the data loss state. At this time, the software needs to deal with the abnormal situation. The processing mode is as follows.<br>The software can query LED_FIFO_DATA_REG to determine which data has been stored in the internal FIFO of LEDC.<br>The LEDC performs soft_reset operation to refresh all data.<br>0: FIFO not overflow<br>1: FIFO overflow |
| 3              | R/W1C      | 0x0         | WAITDATA_TIMEOUT_INT<br>When internal FIFO of LEDC cannot get data because of some abnormal situation, after led_wait_data_time, the timeout interrupt is set, the LEDC is in WAIT_DATA state; in the course of                                                                                                                                                                                                                                                                                                 |

| Offset: 0x0020 |            |             | Register Name: LEDC_INT_STS_REG                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                |            |             | <p>wait_data, if the new data arrives, the LEDC will continue to send data, at this time software needs to notice whether the waiting time of LEDC exceeds the operation time of reset. If the waiting time of LEDC exceeds the operation time of reset (this is equivalent to reset operation sent by LEDC), the LED may enter in refresh state, the data has not been sent.</p> <p>0: LEDC not timeout<br/>1: LEDC timeout</p> |
| 2              | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 1              | R/W1C      | 0x0         | <p>FIFO_CPUREQ_INT<br/>FIFO request CPU data interrupt<br/>When FIFO data is less than the threshold, the interrupt will be reported to the CPU.<br/>0: FIFO does not request that CPU transfers data<br/>1: FIFO requests that CPU transfers data</p>                                                                                                                                                                           |
| 0              | R/W1C      | 0x0         | <p>LED_TRANS_FINISH_INT<br/>Data transfer complete interrupt<br/>The value indicates that the data configured as total_data_length is transferred completely.<br/>0: Data is not transferred completely<br/>1: Data is transferred completely</p>                                                                                                                                                                                |

#### 8.6.6.10 0x0028 LEDC Wait Time 1 Control Register (Default Value: 0x01FF\_FFFF)

| Offset: 0x0028 |            |             | Register Name: LEDC_WAIT_TIME1_CTRL_REG                                                                                                                                                                      |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                  |
| 31             | R/W        | 0x0         | <p>WAIT_TIM1_EN<br/>0: Disable<br/>1: Enable<br/>WAIT_TIME1 enable<br/>When the bit is 1, the controller automatically inserts the waiting time between the LED frame data.</p>                              |
| 30:0           | R/W        | 0x01FFFFFF  | <p>TOTAL_WAIT_TIME1<br/>Waiting time between 2 frame data.<br/>The LEDC output is low level.<br/>The adjust range is 80 ns– 85 s. wait_time1=42 ns*(N+1)<br/>Unit: cycle (24 MHz)<br/>N: 0x80–0x7FFFFFFF</p> |

|                |            |             |                                                |
|----------------|------------|-------------|------------------------------------------------|
| Offset: 0x0028 |            |             | Register Name: LEDC_WAIT_TIME1_CTRL_REG        |
| Bit            | Read/Write | Default/Hex | Description                                    |
|                |            |             | If the value is 0, TOTAL_WAIT_TIME1=0x7FFFFFFF |

#### 8.6.6.11 0x0030+N\*0x04 LEDC FIFO Data Register X (Default Value: 0x0000\_0000)

|                                |            |             |                                                                              |
|--------------------------------|------------|-------------|------------------------------------------------------------------------------|
| Offset: 0x0030+N*0x04 (N=0~31) |            |             | Register Name: LEDC_FIFO_DATA_X                                              |
| Bit                            | Read/Write | Default/Hex | Description                                                                  |
| 31:0                           | R          | 0x0         | LEDC_FIFO_DATA_X<br>Internal FIFO data of LEDC<br>The lower 24-bit is valid. |

## 8.7 Low rate ADC (LRADC)

### 8.7.1 Overview

The low rate analog-to-digital converter (LRADC) can convert the external signal into a certain proportion of digital value, to realize the measurement of analog signal, which can be applied to power detection and key detection.

The LRADC has the following features:

- 2-ch LRADC input
- 6-bit resolution
- Sampling rate up to 2 KHz
- Supports hold key and general key
- Support normal, continue and single work mode
- Power supply voltage:1.8V, power reference voltage:1.35V



#### NOTE

The LRADC has a 6-bit resolution, 1-bit offset error, and 1-bit precision error. After the LRADC calibrates 1-bit offset error, the LRADC has 5-bit precision.

### 8.7.2 Block Diagram

The following figure shows the block diagram of the LRADC.

Figure 8-34 LRADC Block Diagram



### 8.7.3 Functional Description

#### 8.7.3.1 External Signals

The following table describes the external signals of the LRADC. The LRADC pin is the analog input signal.

**Table 8-27 LRADC External Signals**

| Signal Name | Description  | Type |
|-------------|--------------|------|
| LRADC0      | Low Rate ADC | AI   |
| LRADC1      | Low Rate ADC | AI   |

#### 8.7.3.2 Clock Source

The LRADC has one clock source. The following table describes the clock source for LRADC.

**Table 8-28 LRADC Clock Sources**

| Clock Source | Description     |
|--------------|-----------------|
| LOSC         | 32.768 kHz LOSC |

#### 8.7.3.3 LRADC Working Mode

- Normal Mode

The LRADC gathers 8 samples, the average value of these 8 samples is updated in the data register, and the data interrupt sign is enabled. It is sampled repeatedly according to this mode until the LRADC is disabled.

- Continuous Mode

The LRADC gathers 8 samples every other  $8*(N+1)$  sample cycle. The average value of every 8 samples is updated in the data register, and the data interrupt sign is enabled. (N is defined in the bit [19:16] of [LRADC\\_CTRL](#)).

- Single Mode

The LRADC gathers 8 samples, and the average value of these 8 samples is updated in the data register, and the data interrupt sign is enabled at the same time, then the LRADC stops sample.

#### 8.7.3.4 Interrupt

Each LRADC channel has five interrupt sources and five interrupt enable controls.

Figure 8-35 LRADC Interrupt



When the input voltage is between LEVEL A (1.35 V) and LEVEL B (control by the bit [5:4] of [LRADC\\_CTRL](#)), the IRQ1 can be generated. When the input voltage is lower than LEVEL B, the IRQ2 can be generated.

If the controller receives IRQ1 and does not receive IRQ2 at the same time, then the controller will generate Hold Key Pending, otherwise Data IRQ Pending.

The Hold KEY usually is used for the self-locking key. When the self-locking key holds a locking status, the controller receives the IRQ2, then the controller will generate Already Hold Pending.

#### 8.7.3.5 Calculation Formula

Calculation formula:  $\text{LRADC\_DATA} = \text{Vin}/\text{VREF} \times 63$ ,  $\text{VREF}=1.35 \text{ V}$

### 8.7.4 Programming Guidelines

#### 8.7.4.1 Normal Detecting

Perform the following steps for normal detecting mode:

- Step 1 Configure [LRADC\\_BGR\\_REG](#)[LRADC\_GATING] to 0 to disable the clock of LRADC.
- Step 2 Configure [LRADC\\_BGR\\_REG](#)[LRADC\_RST] to 1 to deassert the reset of LRADC.
- Step 3 Configure [LRADC\\_BGR\\_REG](#)[LRADC\_GATING] to 1 to enable the clock of LRADC.
- Step 4 Configure [LRADC\\_CTRL](#)[LRADC\_SAMPLE\_RATE] to set the appropriate sampling frequency.
- Step 5 Configure [LRADC\\_CTRL](#)[LEVELB\_VOL] to set the appropriate voltage threshold.
- Step 6 Configure [LRADC\\_CTRL](#)[FIRST\_CONVERT\_DLY] and [LRADC\\_CTRL](#)[LEVELA\_B\_CNT] to set the appropriate debounce value.
- Step 7 Configure [LRADC\\_CTRL](#)[LRADC\_HOLD\_KEY\_EN] to 1.
- Step 8 Configure [LRADC\\_CTRL](#)[KEY\_MODE\_SELECT] to 0 to set the normal mode.

**Step 9** Configure [LRADC\\_INTC](#) to enable the corresponding interrupt.

**Step 10** Configure [LRADC\\_CTRL](#)[LRADC\_HOLD\_KEY\_EN] to 1.

**Step 11** Read the corresponding key voltage value from LRADC\_DATA when the CPU receives the LRADC interrupt.

#### 8.7.4.2 Single Detecting

Perform the following steps for the single detecting mode:

**Step 1** Configure [LRADC\\_BGR\\_REG](#)[LRADC\_GATING] to 0 to disable the clock of LRADC.

**Step 2** Configure [LRADC\\_BGR\\_REG](#)[LRADC\_RST] to 1 to deassert the reset of LRADC.

**Step 3** Configure [LRADC\\_BGR\\_REG](#)[LRADC\_GATING] to 1 to enable the clock of LRADC.

**Step 4** Configure [LRADC\\_CTRL](#)[LRADC\_SAMPLE\_RATE] to set the appropriate sampling frequency.

**Step 5** Configure [LRADC\\_CTRL](#)[LEVELB\_VOL] to set the appropriate voltage threshold.

**Step 6** Configure [LRADC\\_CTRL](#)[FIRST\_CONVER\_DLY] and [LRADC\\_CTRL](#)[LEVELA\_B\_CNT] to set the appropriate debounce value.

**Step 7** Configure [LRADC\\_CTRL](#)[LRADC\_HOLD\_KEY\_EN] to 1.

**Step 8** Configure [LRADC\\_CTRL](#)[KEY\_MODE\_SELECT] to 1 to set the single mode.

**Step 9** Configure [LRADC\\_INTC](#) to enable the corresponding interrupt.

**Step 10** Configure [LRADC\\_CTRL](#)[LRADC\_HOLD\_KEY\_EN] to 1.

**Step 11** Read the corresponding key voltage value from LRADC\_DATA when the CPU receives the LRADC interrupt.

#### 8.7.4.3 Continuous Detecting

Perform the following steps for continuous detecting mode:

**Step 1** Configure [LRADC\\_BGR\\_REG](#)[LRADC\_GATING] to 0 to disable the clock of LRADC.

**Step 2** Configure [LRADC\\_BGR\\_REG](#)[LRADC\_RST] to 1 to deassert the reset of LRADC.

**Step 3** Configure [LRADC\\_BGR\\_REG](#)[LRADC\_GATING] to 1 to enable the clock of LRADC.

**Step 4** Configure [LRADC\\_CTRL](#)[LRADC\_SAMPLE\_RATE] to set the appropriate sampling frequency.

**Step 5** Configure [LRADC\\_CTRL](#)[LEVELB\_VOL] to set the appropriate voltage threshold.

**Step 6** Configure [LRADC\\_CTRL](#)[FIRST\_CONVER\_DLY] and [LRADC\\_CTRL](#)[LEVELA\_B\_CNT] to set the appropriate debounce value.

- Step 7** Configure [LRADC\\_CTRL](#)[LRADC\_HOLD\_KEY\_EN] to 1.
- Step 8** Configure [LRADC\\_CTRL](#)[KEY\_MODE\_SELECT] to 2 to set the continuous mode, and configure [LRADC\\_CTRL](#)[CONTINUE\_TIME\_SELECT] to set a sampling interval.
- Step 9** Configure [LRADC\\_INTC](#) to enable the corresponding interrupt.
- Step 10** Configure [LRADC\\_CTRL](#)[LRADC\_HOLD\_KEY\_EN] to 1.
- Step 11** Read the corresponding key voltage value from LRADC\_DATA when the CPU receives the LRADC interrupt.

### 8.7.5 Register List

| Module Name | Base Address |
|-------------|--------------|
| LRADC       | 0x02009800   |

| Register Name | Offset | Description                      |
|---------------|--------|----------------------------------|
| LRADC_CTRL    | 0x0000 | LRADC Control Register           |
| LRADC_INTC    | 0x0004 | LRADC Interrupt Control Register |
| LRADC_INTS    | 0x0008 | LRADC Interrupt Status Register  |
| LRADC_DATA0   | 0x000C | LRADC Data Register0             |
| LRADC_DATA1   | 0x0010 | LRADC Data Register1             |

### 8.7.6 Register Description

#### 8.7.6.1 0x0000 LRADC Control Register (Default Value: 0x0100\_0168)

| Offset: 0x0000 |            |             | Register Name: LRADC_CTRL                                                                                                    |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                  |
| 31:24          | R/W        | 0x1         | FIRST_CONVERT_DLY<br>ADC First Convert Delay Setting<br>ADC conversion is delayed by n samples.                              |
| 23:22          | R/W        | 0x0         | CHANNEL_SEL<br>Select the channel that be enabled<br>00: channel 0 only<br>01: channel 1 only<br>10: channel 1 and channel 0 |
| 21:20          | /          | /           | /                                                                                                                            |
| 19:16          | R/W        | 0x0         | CONTINUE_TIME_SELECT<br>Continuous Mode Time Select<br>One of 8*(N+1) sample as a valuable sample data.                      |
| 15:14          | /          | /           | /                                                                                                                            |
| 13:12          | R/W        | 0x0         | KEY_MODE_SELECT                                                                                                              |

| Offset: 0x0000 |            |             | Register Name: LRADC_CTRL                                                                                                                                           |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                         |
|                |            |             | Key Mode Select<br>00: Normal Mode<br>01: Single Mode<br>10: Continuous Mode                                                                                        |
| 11:8           | R/W        | 0x1         | LEVELA_B_CNT<br>Level A to Level B time threshold select<br>Judge the ADC convert value from level A to level B in n+1 samples.                                     |
| 7              | R/W        | 0x0         | LRADC_HOLD_KEY_EN<br>LRADC Hold KEY Enable<br>0: Disable<br>1: Enable                                                                                               |
| 6              | R/W        | 0x1         | LRADC_CHANNEL_EN<br>LRADC Channel Enable<br>0: Disable<br>1: Enable                                                                                                 |
| 5:4            | R/W        | 0x2         | LEVELB_VOL<br>Level B Corresponding Data Value setting (the real voltage value)<br>00: 0x3C (1.286V)<br>01: 0x39 (1.221V)<br>10: 0x36 (1.157V)<br>11: 0x33 (1.093V) |
| 3:2            | R/W        | 0x2         | LRADC_SAMPLE_RATE<br>LRADC Sample Rate<br>00: 2 kHz<br>01: 1 kHz<br>10: 500 Hz<br>11: 250 Hz                                                                        |
| 1              | /          | /           | /                                                                                                                                                                   |
| 0              | R/W        | 0x0         | LRADC_EN<br>LRADC Enable<br>0: Disable<br>1: Enable                                                                                                                 |

#### 8.7.6.2 0x0004 LRADC Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: LRADC_INTC |
|----------------|------------|-------------|---------------------------|
| Bit            | Read/Write | Default/Hex | Description               |
| 31:13          | /          | /           | /                         |
| 12             | R/W        | 0x0         | ADC1_KEYUP_IRQ_EN         |

| Offset: 0x0004 |            |             | Register Name: LRADC_INTC                                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                           |
|                |            |             | ADC1 Key Up IRQ Enable<br>0: Disable<br>1: Enable                                     |
| 11             | R/W        | 0x0         | ADC1_ALRDY_HOLD_IRQ_EN<br>ADC1 Already Hold Key IRQ Enable<br>0: Disable<br>1: Enable |
| 10             | R/W        | 0x0         | ADC1_HOLD_IRQ_EN<br>ADC1 Hold Key IRQ Enable<br>0: Disable<br>1: Enable               |
| 9              | R/W        | 0x0         | ADC1_KEYDOWN_EN<br>ADC1 Key Down Enable<br>0: Disable<br>1: Enable                    |
| 8              | R/W        | 0x0         | ADC1_DATA_IRQ_EN<br>ADC1 Data IRQ Enable<br>0: Disable<br>1: Enable                   |
| 7:5            | /          | /           | /                                                                                     |
| 4              | R/W        | 0x0         | ADC0_KEYUP_IRQ_EN<br>ADC0 Key Up IRQ Enable<br>0: Disable<br>1: Enable                |
| 3              | R/W        | 0x0         | ADC0_ALRDY_HOLD_IRQ_EN<br>ADC0 Already Hold Key IRQ Enable<br>0: Disable<br>1: Enable |
| 2              | R/W        | 0x0         | ADC0_HOLD_IRQ_EN<br>ADC0 Hold Key IRQ Enable<br>0: Disable<br>1: Enable               |
| 1              | R/W        | 0x0         | ADC0_KEYDOWN_EN<br>ADC0 Key Down Enable<br>0: Disable<br>1: Enable                    |
| 0              | R/W        | 0x0         | ADC0_DATA_IRQ_EN<br>ADC0 Data IRQ Enable<br>0: Disable<br>1: Enable                   |

## 8.7.6.3 0x0008 LRADC Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0008 |            |             | Register Name: LRADC_INTS                                                                                                                                                                                                                                                                                                         |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                       |
| 31:13          | /          | /           | /                                                                                                                                                                                                                                                                                                                                 |
| 12             | R/W1C      | 0x0         | <p>ADC1_KEYUP_PENDING<br/>ADC1 Key up pending Bit<br/>When general Key pull up, it the corresponding interrupt is enabled.<br/>0: No IRQ<br/>1: IRQ Pending<br/>Writing 1 to the bit will clear it and its corresponding interrupt if the interrupt is enabled.</p>                                                               |
| 11             | R/W1C      | 0x0         | <p>ADC1_ALRDY_HOLD_PENDING<br/>ADC1 Already Hold Pending Bit<br/>When hold Key pull down and pull the general key down, if the corresponding interrupt is enabled.<br/>0: No IRQ<br/>1: IRQ Pending<br/>Writing 1 to the bit will clear it and its corresponding interrupt if the interrupt is enabled.</p>                       |
| 10             | R/W1C      | 0x0         | <p>ADC1_HOLDKEY_PENDING<br/>ADC1 Hold Key Pending Bit<br/>When Hold Key pull down, the status bit is set and the interrupt line is set if the corresponding interrupt is enabled.<br/>0: NO IRQ<br/>1: IRQ Pending<br/>Writing 1 to the bit will clear it and its corresponding interrupt if the interrupt is enabled.</p>        |
| 9              | R/W1C      | 0x0         | <p>ADC1_KEYDOWN_PENDING<br/>ADC1 Key Down IRQ Pending Bit<br/>When General Key pull down, the status bit is set and the interrupt line is set if the corresponding interrupt is enabled.<br/>0: No IRQ<br/>1: IRQ Pending<br/>Writing 1 to the bit will clear it and its corresponding interrupt if the interrupt is enabled.</p> |
| 8              | R/W1C      | 0x0         | <p>ADC1_DATA_PENDING<br/>ADC1 Data IRQ Pending Bit<br/>0: No IRQ<br/>1: IRQ Pending</p>                                                                                                                                                                                                                                           |

| Offset: 0x0008 |            |             | Register Name: LRADC_INTS                                                                                                                                                                                                                                                                                                                    |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                  |
|                |            |             | Writing 1 to the bit will clear it and its corresponding interrupt if the interrupt is enabled.                                                                                                                                                                                                                                              |
| 7:5            | /          | /           | /                                                                                                                                                                                                                                                                                                                                            |
| 4              | R/W1C      | 0x0         | <p>ADC0_KEYUP_PENDING<br/>ADC0 Key up Pending Bit<br/>When the general key is pulled up, and the corresponding interrupt is enabled, the status bit is set.<br/>0: No IRQ<br/>1: IRQ Pending<br/>Writing 1 to the bit will clear it and its corresponding interrupt if the interrupt is enabled.</p>                                         |
| 3              | R/W1C      | 0x0         | <p>ADC0_ALRDY_HOLD_PENDING<br/>ADC0 Already Hold Pending Bit<br/>When the hold key is pulled down and the general key is pulled down, and the corresponding interrupt is enabled.<br/>0: No IRQ<br/>1: IRQ Pending<br/>Writing 1 to the bit will clear it and its corresponding interrupt if the interrupt is enabled.</p>                   |
| 2              | R/W1C      | 0x0         | <p>ADC0_HOLDKEY_PENDING<br/>ADC0 Hold Key Pending Bit<br/>When the hold key is pulled down, and the corresponding interrupt is enabled, the status bit is set and the interrupt line is set.<br/>0: NO IRQ<br/>1: IRQ Pending<br/>Writing 1 to the bit will clear it and its corresponding interrupt if the interrupt is enabled.</p>        |
| 1              | R/W1C      | 0x0         | <p>ADC0_KEYDOWN_PENDING<br/>ADC0 Key Down IRQ Pending Bit<br/>When the general key is pulled down, and the corresponding interrupt is enabled, the status bit is set and the interrupt line is set.<br/>0: No IRQ<br/>1: IRQ Pending<br/>Writing 1 to the bit will clear it and its corresponding interrupt if the interrupt is enabled.</p> |
| 0              | R/W1C      | 0x0         | ADC0_DATA_PENDING<br>ADC0 Data IRQ Pending Bit                                                                                                                                                                                                                                                                                               |

| Offset: 0x0008 |            |             | Register Name: LRADC_INTS                                                                                                      |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                    |
|                |            |             | 0: No IRQ<br>1: IRQ Pending<br>Writing 1 to the bit will clear it and its corresponding interrupt if the interrupt is enabled. |

#### 8.7.6.4 0x000C LRADC Data Register (Default Value: 0x0000\_003F)

| Offset: 0x000C |            |             | Register Name: LRADC_DATA0 |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:6           | /          | /           | /                          |
| 5:0            | R          | 0x3F        | LRADC0_DATA<br>LRADC0 Data |

#### 8.7.6.5 0x0010 LRADC Data Register (Default Value: 0x0000\_003F)

| Offset: 0x0010 |            |             | Register Name: LRADC_DATA1 |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:6           | /          | /           | /                          |
| 5:0            | R          | 0x3F        | LRADC1_DATA<br>LRADC1 Data |

## 8.8 USB2.0 DRD

### 8.8.1 Overview

The USB2.0 dual-role device (USB2.0 DRD) supports both device and host functions which can also be configured as a Host-only or Device-only controller. It complies with the USB2.0 Specification.

For saving CPU bandwidth, the DMA interface of the DRD module can also support the external DMA controller to do the data transfer between the memory and the DRD FIFO. The DRD core also supports USB power saving functions.

The USB2.0 DRD has the following features:

- One USB2.0 DRD (USB0), with integrated USB 2.0 analog PHY
- Complies with USB2.0 Specification
- USB Host that supports the following:
  - Compatible with Enhanced Host Controller Interface (EHCI) Specification, Version 1.0
  - Compatible with Open Host Controller Interface (OHCI) Specification, Version 1.0a
  - Supports High-Speed (HS, 480 Mbit/s), Full-Speed (FS, 12 Mbit/s), and Low-Speed (LS, 1.5 Mbit/s)
  - Supports only 1 USB Root port shared between EHCl and OHCI
- USB Device that supports the following:
  - Supports High-Speed (HS, 480 Mbit/s), Full-Speed (FS, 12 Mbit/s)
  - Supports bi-directional endpoint0 (EP0) for Control transfer
  - Up to 10 user-configurable endpoints (EP1 IN/OUT, EP2 IN/OUT, EP3 IN/OUT, EP4 IN/OUT, EP5 IN/OUT) for Bulk transfer, Isochronous transfer and Interrupt transfer
  - Up to (8 KB + 64 Bytes) FIFO for all EPs (including EP0)
  - Supports interface to an external Normal DMA controller for every EP
- Supports an internal DMA controller for data transfer with memory
- Supports High-Bandwidth Isochronous & Interrupt transfers
- Automated splitting/combining of packets for Bulk transfers
- Supports point-to-point and point-to-multipoint transfer in both Host and Peripheral modes
- Includes automatic PING capabilities
- Soft connect/disconnect function
- Performs all transaction scheduling in hardware
- Power optimization and power management capabilities

- Device and host controller share an 8K SRAM and a physical PHY

### 8.8.2 Block Diagram

The following figure shows the block diagram of USB2.0 DRD Controller.

Figure 8-36 USB2.0 DRD Controller Block Diagram



### 8.8.3 Functional Description

#### 8.8.3.1 External Signals

Table 8-29 USB2.0 DRD External Signals

| Signal Name  | Description                                                   | Type  |
|--------------|---------------------------------------------------------------|-------|
| USB0-DM      | USB2.0 Data Signal DM                                         | A I/O |
| USB0-DP      | USB2.0 Data Signal DP                                         | A I/O |
| USB0-REXT    | USB2.0 External Reference Resistor                            | AO    |
| VCC33-USB    | 3.3 V Analog Power Supply for USB2.0 DRD and USB2.0 Host      | P     |
| VCC33-18-USB | 3.3 V/1.8V Analog Power Supply for USB2.0 DRD and USB2.0 Host | P     |
| VDD09-USB    | 0.9 V USB Digital Power Supply                                | p     |

### 8.8.3.2 Controller and PHY Connection Diagram

Figure 8-37 USB2.0 DRD Controller and PHY Connection Diagram



### 8.8.4 Register List

There are two groups of registers in USB2.0 DRD.

| Module Name                      | Base Address |
|----------------------------------|--------------|
| USB0 (0x0410 0000---0x041F FFFF) |              |
| USB_DRD_DEVICE                   | 0x04100000   |
| USB_DRD_HOST                     | 0x04101000   |

#### 8.8.4.1 USB\_DRD\_DEVICE Register List

| Module Name    | Base Address |
|----------------|--------------|
| USB_DRD_DEVICE | 0x04100000   |

| Register Name | Offset                                     | Description                            |
|---------------|--------------------------------------------|----------------------------------------|
| USB_EPFIFOon  | 0x0000+N<br>*0x0004<br>(N=0,1,2,3<br>,4,5) | USB FIFO Entry for Endpoint N          |
| USB_GCS       | 0x0040                                     | USB Global Control and Status Register |
| USB_EPINTF    | 0x0044                                     | USB Endpoint Interrupt Flag Register   |
| USB_EPINTE    | 0x0048                                     | USB Endpoint Interrupt Enable Register |
| USB_BUSINTF   | 0x004C                                     | USB Bus Interrupt Flag Register        |
| USB_BUSINTE   | 0x0050                                     | USB Bus Interrupt Enable Register      |

| Register Name       | Offset                         | Description                               |
|---------------------|--------------------------------|-------------------------------------------|
| USB_FNUM            | 0x0054                         | USB Frame Number Register                 |
| USB_TESTC           | 0x007C                         | USB Test Control Register                 |
| USB_CSR0            | 0x0080                         | USB EP0 Control and Status Register       |
| USB_TXCSR           | 0x0080                         | USB EP1-5 Tx Control and Status Register  |
| USB_RXCSR           | 0x0084                         | USB EP1-5 Rx Control and Status Register  |
| USB_COUNT0          | 0x0088                         | USB EP0 Rx Counter Register               |
| USB_RXCOUNT         | 0x0088                         | USB EP1-5 Rx Counter Register             |
| USB_ATTR0           | 0x008C                         | USB EP0 Attribute Register                |
| USB_EPATTR          | 0x008C                         | USB EP1-5 Attribute Register              |
| USB_TXFIFO          | 0x0090                         | USB EP1-5 TxFIFO Setting Register         |
| USB_RXFIFO          | 0x0094                         | USB EP1-5 RxFIFO Setting Register         |
| USB_FADDR           | 0x0098                         | USB Function Address Register             |
| USB_ISCR            | 0x0400                         | USB Interface Status and Control Register |
| USB_PHY_CTL         | 0x0410                         | USB PHY Control Register                  |
| USB_PHY_TEST        | 0x0414                         | USB PHY Test Register                     |
| USB_PHY_TUNE        | 0x0418                         | USB PHY Tune Register                     |
| USB_PHY_SEL         | 0x0420                         | USB PHY Select Register                   |
| USB_PHY_STA         | 0x0424                         | USB PHY Status Register                   |
| USB_DMA_INTE        | 0x0500                         | USB DMA Interrupt Enable Register         |
| USB_DMA_INTS        | 0x0504                         | USB DMA Interrupt Status Register         |
| USB_DMA_CHAN_CFG    | 0x0540+N<br>*0x0010(N<br>=0-7) | USB DMA Channel Configuration Register    |
| USB_DMA_SDRAM_ADD   | 0x0544+N<br>*0x0010(N<br>=0-7) | USB DMA SDRAM Start Address Register      |
| USB_DMA_BC          | 0x0548+N<br>*0x0010(N<br>=0-7) | USB DMA Byte Counter Register             |
| USB_DMA_RESIDUAL_BC | 0x054C+N<br>*0x0010(N<br>=0-7) | USB DMA RESIDUAL Byte Counter Register    |

#### 8.8.4.2 USB\_DRD\_HOST Register List

| Module Name  | Base Address |
|--------------|--------------|
| USB_DRD_HOST | 0x04101000   |

#### EHCI

| Register Name | Offset | Description                  |
|---------------|--------|------------------------------|
| E_CAPLENGTH   | 0x0000 | EHCI Identification Register |

| Register Name      | Offset | Description                                     |
|--------------------|--------|-------------------------------------------------|
| E_HCIVERSION       | 0x0002 | EHCI Host Interface Version Number Register     |
| E_HCSPARAMS        | 0x0004 | EHCI Host Control Structural Parameter Register |
| E_HCCPARAMS        | 0x0008 | EHCI Host Control Capability Parameter Register |
| E_HCSPPORTROUTE    | 0x000C | EHCI Companion Port Route Description           |
| E_USBCMD           | 0x0010 | EHCI USB Command Register                       |
| E_USBSTS           | 0x0014 | EHCI USB Status Register                        |
| E_USBINTR          | 0x0018 | EHCI USB Interrupt Enable Register              |
| E_FRINDEX          | 0x001C | EHCI USB Frame Index Register                   |
| E_PERIODICLISTBASE | 0x0024 | EHCI Periodic Frame List Base Address Register  |
| E_ASYNCNLISTADDR   | 0x0028 | EHCI Current Asynchronous List Address Register |
| E_CONFIGFLAG       | 0x0050 | EHCI Configured Flag Register                   |
| E_PORTSC           | 0x0054 | EHCI Port Status and Control Register           |

### OHCI

| Register Name        | Offset | Description                        |
|----------------------|--------|------------------------------------|
| O_HcRevision         | 0x0400 | OHCI Revision Register             |
| O_HcControl          | 0x0404 | OHCI Control Register              |
| O_HcCommandStatus    | 0x0408 | OHCI Command Status Register       |
| O_HcInterruptStatus  | 0x040C | OHCI Interrupt Status Register     |
| O_HcInterruptEnable  | 0x0410 | OHCI Interrupt Enable Register     |
| O_HcInterruptDisable | 0x0414 | OHCI Interrupt Disable Register    |
| O_HcHCCA             | 0x0418 | OHCI HCCA Register                 |
| O_HcPeriodCurrentED  | 0x041C | OHCI Period Current ED Register    |
| O_HcControlHeadED    | 0x0420 | OHCI Control Head ED Register      |
| O_HcControlCurrentED | 0x0424 | OHCI Control Current ED Register   |
| O_HcBulkHeadED       | 0x0428 | OHCI Bulk Head ED Register         |
| O_HcBulkCurrentED    | 0x042C | OHCI Bulk Current ED Register      |
| O_HcDoneHead         | 0x0430 | OHCI Done Head Register            |
| O_HcFmInterval       | 0x0434 | OHCI Frame Interval Register       |
| O_HcFmRemaining      | 0x0438 | OHCI Frame Remaining Register      |
| O_HcFmNumber         | 0x043C | OHCI Frame Number Register         |
| O_HcPeriodicStart    | 0x0440 | OHCI Periodic Start Register       |
| O_HcLSThreshold      | 0x0444 | OHCI LS Threshold Register         |
| O_HcRhDescriptorA    | 0x0448 | OHCI Root Hub DescriptorA Register |
| O_HcRhDescriptorB    | 0x044C | OHCI Root Hub DescriptorB Register |
| O_HcRhStatus         | 0x0450 | OHCI Root Hub Status Register      |
| O_HcRhPortStatus     | 0x0454 | OHCI Root Hub Port Status Register |

### HCI

| Register Name | Offset | Description |
|---------------|--------|-------------|
|               |        |             |

| Register Name | Offset | Description                           |
|---------------|--------|---------------------------------------|
| USB_CTRL      | 0x0800 | HCI Interface Register                |
| HCI_CTRL3     | 0x0808 | HCI Control 3 Register                |
| PHY_CTRL      | 0x0810 | PHY Control Register                  |
| PHY_TEST      | 0x0814 | PHY Test Register                     |
| PHY_TUNE      | 0x0818 | PHY Tune Register                     |
| PHY_STA       | 0x0824 | PHY Status Register                   |
| USB_SPDCR     | 0x0828 | HCI SIE Port Disable Control Register |

### 8.8.5 USB\_DRD\_Device Register Description

#### 8.8.5.1 0x0000+N\*0x04(N=0-5) USB FIFO Entry for Endpoint N (Default Value:0x0000\_0000)

| Offset: 0x0000+N*0x04(N=0-5) |            |             | Register Name: USB_EPFIFO[n]         |
|------------------------------|------------|-------------|--------------------------------------|
| Bit                          | Read/Write | Default/Hex | Description                          |
| 31:0                         | R/W        | UDF         | EPnFIFO<br>FIFO Entry for Endpoint n |

#### 8.8.5.2 0x0040 USB Global Control and Status Register (Default Value:0x0000\_0020)

| Offset: 0x0040 |            |             | Register Name: USB_GCS                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                         |
| 31             | R/W        | 0           | TX_EDMA<br>1'b0: DMA_REQ signal for all IN Endpoints will be de-asserted when MAXP bytes have been written to endpoint. This is late mode.<br>1'b1: DMA_REQ signal for all IN Endpoints will be de-asserted when MAXP-8 bytes have been written to an endpoint. This is early mode. |
| 30             | R/W        | 0           | RX_EDMA<br>1'b0: DMA_REQ signal for all OUT Endpoints will be de-asserted when MAXP bytes have been read to an endpoint. This is late mode.<br>1'b1: DMA_REQ signal for all OUT Endpoints will be de-asserted when MAXP-8 bytes have been read to an endpoint. This is early mode.  |
| 29             | /          | /           | /                                                                                                                                                                                                                                                                                   |
| 28:25          | R/W        | 0           | BUS_DRQ_SEL<br>USB DMA Request Signal Source Select<br>4'b0000: Select TX Endpoint 1 DRQ<br>4'b0001: Select RX Endpoint 1 DRQ<br>4'b0010: Select TX Endpoint 2 DRQ                                                                                                                  |

| Offset: 0x0040 |            |                                | Register Name: USB_GCS                                                                                                                                                                                                                                                                                                                                                                                                                                      |    |    |         |   |   |                  |   |   |                                |   |   |                               |   |   |                 |
|----------------|------------|--------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|---------|---|---|------------------|---|---|--------------------------------|---|---|-------------------------------|---|---|-----------------|
| Bit            | Read/Write | Default/Hex                    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                 |    |    |         |   |   |                  |   |   |                                |   |   |                               |   |   |                 |
|                |            |                                | 4'b0011: Select RX Endpoint 2 DRQ<br>4'b0100: Select TX Endpoint 3 DRQ<br>4'b0101: Select RX Endpoint 3 DRQ<br>4'b0110: Select TX Endpoint 4 DRQ<br>4'b0111: Select RX Endpoint 4 DRQ<br>4'b1000: Select TX Endpoint 5 DRQ<br>4'b1001: Select RX Endpoint 5 DRQ                                                                                                                                                                                             |    |    |         |   |   |                  |   |   |                                |   |   |                               |   |   |                 |
| 24             | R/W        | 0                              | <b>FIFO_BUS_SEL</b><br>0: CPU bus for FIFO Access,<br>1: DMA bus for FIFO operation.                                                                                                                                                                                                                                                                                                                                                                        |    |    |         |   |   |                  |   |   |                                |   |   |                               |   |   |                 |
| 23:20          | /          | /                              | /                                                                                                                                                                                                                                                                                                                                                                                                                                                           |    |    |         |   |   |                  |   |   |                                |   |   |                               |   |   |                 |
| 19:16          | R/W        | 0x0                            | <b>EPIND</b><br><b>Endpoint Index</b><br>Index is a 4-bit register that determines which endpoint control/status registers are accessed.<br>Before accessing an endpoint's control/status registers at 0x0080-0x00BF, the endpoint number should be written to the Index register to ensure that correct control/status registers in the memory map.<br><b>Note: The valid value for Index register is 0-5.</b>                                             |    |    |         |   |   |                  |   |   |                                |   |   |                               |   |   |                 |
| 15             | R          | 0                              | <b>BDev</b><br><b>B-Device</b><br>0 => 'A' device;<br>1 => 'B' device;<br>Only valid while a session is in progress.<br><b>Note: If the core is in Force_Host mode (i.e. a session has been started with USB_TMCTL.7=1), this bit will indicate the state of the HOSTDISCON input signal from the PHY.</b>                                                                                                                                                  |    |    |         |   |   |                  |   |   |                                |   |   |                               |   |   |                 |
| 14:13          | /          | /                              | /                                                                                                                                                                                                                                                                                                                                                                                                                                                           |    |    |         |   |   |                  |   |   |                                |   |   |                               |   |   |                 |
| 12:11          | R          | 0x0                            | <b>VBus</b><br>These bits encode the current VBus level as follows: <table border="1"> <thead> <tr> <th>D4</th> <th>D3</th> <th>Meaning</th> </tr> </thead> <tbody> <tr> <td>0</td> <td>0</td> <td>Below SessionEnd</td> </tr> <tr> <td>0</td> <td>1</td> <td>Above SessionEnd, below AValid</td> </tr> <tr> <td>1</td> <td>0</td> <td>Above AValid, below VBusValid</td> </tr> <tr> <td>1</td> <td>1</td> <td>Above VBusValid</td> </tr> </tbody> </table> | D4 | D3 | Meaning | 0 | 0 | Below SessionEnd | 0 | 1 | Above SessionEnd, below AValid | 1 | 0 | Above AValid, below VBusValid | 1 | 1 | Above VBusValid |
| D4             | D3         | Meaning                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                             |    |    |         |   |   |                  |   |   |                                |   |   |                               |   |   |                 |
| 0              | 0          | Below SessionEnd               |                                                                                                                                                                                                                                                                                                                                                                                                                                                             |    |    |         |   |   |                  |   |   |                                |   |   |                               |   |   |                 |
| 0              | 1          | Above SessionEnd, below AValid |                                                                                                                                                                                                                                                                                                                                                                                                                                                             |    |    |         |   |   |                  |   |   |                                |   |   |                               |   |   |                 |
| 1              | 0          | Above AValid, below VBusValid  |                                                                                                                                                                                                                                                                                                                                                                                                                                                             |    |    |         |   |   |                  |   |   |                                |   |   |                               |   |   |                 |
| 1              | 1          | Above VBusValid                |                                                                                                                                                                                                                                                                                                                                                                                                                                                             |    |    |         |   |   |                  |   |   |                                |   |   |                               |   |   |                 |
| 10             | R          | 0                              | <b>HostMode</b><br>Host Mode                                                                                                                                                                                                                                                                                                                                                                                                                                |    |    |         |   |   |                  |   |   |                                |   |   |                               |   |   |                 |

| Offset: 0x0040 |            |             | Register Name: USB_GCS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                |            |             | This bit is set when the USB/DRD is acting as a Host.                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 9              | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 8              | R/W        | 0           | <p>Session<br/>When operating as an 'A' device, this bit is set or cleared by the CPU to start or end a session.<br/>When operating as an 'B' device, this bit is set/cleared by the USB/DRD when a session starts/ends. It is also set by the CPU to initiate the Session Request Protocol.<br/>When the USB/DRD is in Suspend mode, the bit may be cleared by the CPU to perform a software disconnect.</p> <p><b>Note:</b> Clearing this bit when the core is not suspending will result in undefined behavior.</p> |
| 7              | R/W        | 0           | <p>IsoUpdateEn<br/>Isochronous Update Enable<br/>When set by the CPU, the USB/DRD will wait for an SOF token from the Tx packet ready before sending the packet. If an IN token is received before an SOF token, then a zero length data packet will be send.</p> <p><b>Note:</b> This bit only affects endpoints performing Isochronous transfer.</p>                                                                                                                                                                 |
| 6              | R/W        | 0           | <p>SoftConn<br/>Soft Connect<br/>The USB D+/D- line is enabled when this bit is set by CPU and tri-stated when this bit is cleared by CPU.</p> <p><b>Note:</b> Only valid in Peripheral Mode (but not means 'B' Device ).</p>                                                                                                                                                                                                                                                                                          |
| 5              | R/W        | 1           | <p>HSEN<br/>High-speed Mode Enable<br/>When set by CPU, the USB/DRD will negotiate for High-speed mode when the device is reset by host. If not set, the device will only operate in Full-speed mode.</p>                                                                                                                                                                                                                                                                                                              |
| 4              | R          | 0           | <p>HSFLAG<br/>High-speed Mode Flag<br/>When set, this read-only bit indicates High-speed mode successfully negotiated during USB reset. And this bit becomes valid when USB Reset completes (as indicated by USB reset interrupt).</p>                                                                                                                                                                                                                                                                                 |
| 3              | R          | 0           | Reset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Offset: 0x0040 |            |             | Register Name: USB_GCS                                                                                                                                                              |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                         |
|                |            |             | This bit is set when Reset Signaling is present on the bus.                                                                                                                         |
| 2              | R/W        | 0           | Resume<br>Set by the CPU to generate Resume signaling when the function is in Suspend mode. The CPU should clear this bit after 10 ms (a maximum of 15 ms) to end Resume signaling. |
| 1              | R          | 0           | SuspendM<br>Suspend Mode<br>This bit is set on entry into Suspend mode.                                                                                                             |
| 0              | R/W        | 0           | SuspendMEn<br>Enable SuspendM<br>Set by the CPU to enable the SUSPENDM output of UTMI+ bus.                                                                                         |

#### 8.8.5.3 0x0044 USB Endpoint Interrupt Flag Register (Default Value:0x0000\_0000)

| Offset: 0x0044 |            |             | Register Name: USB_EPINTF             |
|----------------|------------|-------------|---------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                           |
| 31:22          | /          | /           | /                                     |
| 21             | R          | 0           | EP5Rx<br>Rx Endpoint 5 interrupt flag |
| 20             | R          | 0           | EP4Rx<br>Rx Endpoint 4 interrupt flag |
| 19             | R          | 0           | EP3Rx<br>Rx Endpoint 3 interrupt flag |
| 18             | R          | 0           | EP2Rx<br>Rx Endpoint 2 interrupt flag |
| 17             | R          | 0           | EP1Rx<br>Rx Endpoint 1 interrupt flag |
| 16:6           | /          | /           | /                                     |
| 5              | R          | 0           | EP5Tx<br>Tx Endpoint 5 interrupt flag |
| 4              | R          | 0           | EP4Tx<br>Tx Endpoint 4 interrupt flag |
| 3              | R          | 0           | EP3Tx<br>Tx Endpoint 3 interrupt flag |
| 2              | R          | 0           | EP2Tx<br>Tx Endpoint 2 interrupt flag |
| 1              | R          | 0           | EP1Tx                                 |

| Offset: 0x0044 |            |             | Register Name: USB_EPINTF        |
|----------------|------------|-------------|----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                      |
|                |            |             | Tx Endpoint 1 interrupt flag     |
| 0              | R          | 0           | EP0<br>Endpoint 0 interrupt flag |

#### 8.8.5.4 0x0048 USB Endpoint Interrupt Enable Register (Default Value:0x0000\_0000)

| Offset: 0x0048 |            |             | Register Name: USB_EPINTE               |
|----------------|------------|-------------|-----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                             |
| 31:22          | /          | /           | /                                       |
| 21             | R/W        | 0           | EP5Rx<br>Rx Endpoint 5 interrupt enable |
| 20             | R/W        | 0           | EP4Rx<br>Rx Endpoint 4 interrupt enable |
| 19             | R/W        | 0           | EP3Rx<br>Rx Endpoint 3 interrupt enable |
| 18             | R/W        | 0           | EP2Rx<br>Rx Endpoint 2 interrupt enable |
| 17             | R/W        | 0           | EP1Rx<br>Rx Endpoint 1 interrupt enable |
| 16:6           | /          | /           | /                                       |
| 5              | R/W        | 0           | EP5Tx<br>Tx Endpoint 5 interrupt enable |
| 4              | R/W        | 0           | EP4Tx<br>Tx Endpoint 4 interrupt enable |
| 3              | R/W        | 0           | EP3Tx<br>Tx Endpoint 3 interrupt enable |
| 2              | R/W        | 0           | EP2Tx<br>Tx Endpoint 2 interrupt enable |
| 1              | R/W        | 0           | EP1Tx<br>Tx Endpoint 1 interrupt enable |
| 0              | R/W        | 0           | EP0<br>Endpoint 0 interrupt enable      |

#### 8.8.5.5 0x004C USB Bus Interrupt Flag Register (Default Value:0x0000\_0000)

| Offset: 0x004C |            |             | Register Name: USB_BUSINTF                                      |
|----------------|------------|-------------|-----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                     |
| 31:8           | /          | /           | /                                                               |
| 7              | R          | 0           | VBusError<br>Set when VBus drops below the VBus Valid threshold |

| Offset: 0x004C |            |             | Register Name: USB_BUSINTF                                                                                                                                                                                    |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                   |
|                |            |             | during a session.<br><b>Note:</b> Only valid when USB/DRD is 'A' device.                                                                                                                                      |
| 6              | R          | 0           | SessionRequest<br>Set when Session Request signaling has been detected.<br><b>Note:</b> Only valid when USB/DRD is 'A' device.                                                                                |
| 5              | R          | 0           | Disconnect<br>Set in Host mode when a device disconnect is detected. Set in Peripheral mode when a session ends.<br><b>Note:</b> Valid at all transaction speeds.                                             |
| 4              | R          | 0           | Connect<br>Set in host mode when a device connection is detected.<br><b>Note:</b> Only valid in Host mode. Valid at all transaction speeds.                                                                   |
| 3              | R          | 0           | SOF<br>Set when a new frame starts.                                                                                                                                                                           |
| 2              | R          | 0           | ResetBabble<br>Reset<br>Set in Peripheral mode when Reset signaling is detected on the bus.<br>Babble<br>Set in Host mode when babble is detected.<br><b>Note:</b> Only active after first SOF has been sent. |
| 1              | R          | 0           | Resume<br>Set when Resume signaling is detected on the bus while the USB/DRD is in Suspend mode.                                                                                                              |
| 0              | R          | 0           | Suspend<br>Set when Suspend signaling is detected on the bus.<br><b>Note:</b> Only valid in Peripheral mode.                                                                                                  |

#### 8.8.5.6 0x0050 USB Bus Interrupt Enable Register (Default Value:0x0000\_0000)

| Offset: 0x0050 |            |             | Register Name: USB_BUSINTE                          |
|----------------|------------|-------------|-----------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                         |
| 31:8           | /          | /           | /                                                   |
| 7              | R/W        | 0           | VBusError<br>VBusError interrupt enable             |
| 6              | R/W        | 0           | Session Request<br>Session Request interrupt enable |

| Offset: 0x0050 |            |             | Register Name: USB_BUSINTE                                                          |
|----------------|------------|-------------|-------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                         |
| 5              | R/W        | 0           | Disconnect<br>Disconnect interrupt enable                                           |
| 4              | R/W        | 0           | Connect<br>Connect interrupt enable                                                 |
| 3              | R/W        | 0           | SOF<br>SOF interrupt enable                                                         |
| 2              | R/W        | 0           | ResetBabble<br>Reset<br>Reset interrupt enable<br>Babble<br>Babble interrupt enable |
| 1              | R/W        | 0           | Resume<br>Resume interrupt enable                                                   |
| 0              | R/W        | 0           | Suspend<br>Suspend interrupt enable                                                 |

#### 8.8.5.7 0x0054 USB Frame Number Register (Default Value:0x0000\_0000)

| Offset: 0x0054 |            |             | Register Name: USB_FNUM                                       |
|----------------|------------|-------------|---------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                   |
| 31:11          | /          | /           | /                                                             |
| 10:0           | R          | 0x000       | FRNUM<br>Frame Number<br>Hold the last received frame number. |

#### 8.8.5.8 0x007C USB Test Control Register (Default Value:0x0000\_0000)



Only one of Bits 0-6 should be set at any time.

| Offset: 0x007C |            |             | Register Name: USB_TESTC                            |
|----------------|------------|-------------|-----------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                         |
| 31:24          | /          | 0           | /                                                   |
| 23:16          | R          | /           | FSM<br>USB Operation Finite State Machine for Debug |
| 15:11          | /          | /           | /                                                   |
| 10             | R/W        | 0           | EXTRXACT<br>Extend Rx Active Signal for safe        |

| Offset: 0x007C |            |                 | Register Name: USB_TESTC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |          |          |                 |   |   |           |   |   |            |   |   |            |   |   |           |
|----------------|------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|----------|-----------------|---|---|-----------|---|---|------------|---|---|------------|---|---|-----------|
| Bit            | Read/Write | Default/Hex     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |          |          |                 |   |   |           |   |   |            |   |   |            |   |   |           |
| 9              | R/W        | 0               | RESUME_SE0<br>Resume from SE0 Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |          |          |                 |   |   |           |   |   |            |   |   |            |   |   |           |
| 8              | R/W        | 0               | TM1<br>Test Mode Enable for Simulation.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |          |          |                 |   |   |           |   |   |            |   |   |            |   |   |           |
| 7              | R/W        | 0               | <p>Force_Host</p> <p>The CPU sets this bit to instruct the core to enter Host mode when the Session bit (Bit 0 of USB_DEVCTL) is set, regardless of whether it is connected to any peripheral. The state of the CID input, HostDisconnect and Linestate signals are ignored. The core will then remain in Host mode until the Session bit is cleared, even if a device is disconnected, and if the Force_Host bit remains set, will re-enter Host mode the next time the Session bit is set.</p> <p>While in this mode, the status of the HOSTDISCON signal from the PHY may be read from bit 7 of the USB_DEVCTL (in 0x0060) register.</p> <p>The operating speed is determined from the Force_HS and Force_FS bits as follows:</p> <table border="1"> <tr> <th>Force_HS</th><th>Force_FS</th><th>Operating Speed</th></tr> <tr> <td>0</td><td>0</td><td>Low Speed</td></tr> <tr> <td>0</td><td>1</td><td>Full Speed</td></tr> <tr> <td>1</td><td>0</td><td>High Speed</td></tr> <tr> <td>1</td><td>1</td><td>Undefined</td></tr> </table> | Force_HS | Force_FS | Operating Speed | 0 | 0 | Low Speed | 0 | 1 | Full Speed | 1 | 0 | High Speed | 1 | 1 | Undefined |
| Force_HS       | Force_FS   | Operating Speed |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |          |          |                 |   |   |           |   |   |            |   |   |            |   |   |           |
| 0              | 0          | Low Speed       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |          |          |                 |   |   |           |   |   |            |   |   |            |   |   |           |
| 0              | 1          | Full Speed      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |          |          |                 |   |   |           |   |   |            |   |   |            |   |   |           |
| 1              | 0          | High Speed      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |          |          |                 |   |   |           |   |   |            |   |   |            |   |   |           |
| 1              | 1          | Undefined       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |          |          |                 |   |   |           |   |   |            |   |   |            |   |   |           |
| 6              | W          | 0               | <p>FIFO_Access</p> <p>The CPU sets this bit to transfer the packet in the Endpoint 0 Tx FIFO to the Endpoint 0 Rx FIFO. It is cleared automatically.</p> <p><b>Note: Writing '0' to this bit will be ignored.</b></p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |          |          |                 |   |   |           |   |   |            |   |   |            |   |   |           |
| 5              | R/W        | 0               | <p>Force_FS</p> <p>The CPU sets this bit either in conjunction with bit 7 above or to force the USB/DRD into Full-speed mode when it receives a USB reset.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |          |          |                 |   |   |           |   |   |            |   |   |            |   |   |           |
| 4              | R/W        | 0               | <p>Force_HS</p> <p>The CPU sets this bit either in conjunction with bit 7 above or to force the USB/DRD into High-speed mode when it receives a USB reset.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |          |          |                 |   |   |           |   |   |            |   |   |            |   |   |           |
| 3              | R/W        | 0               | <p>Test_Packet</p> <p>(High-speed mode) The CPU sets this bit to enter</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |          |          |                 |   |   |           |   |   |            |   |   |            |   |   |           |

| Offset: 0x007C |            |             | Register Name: USB_TESTC                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                              |
|                |            |             | <p>Test_Packet test mode. In the mode, the USB/DRD repetitively transmits on the bus a 53-byte test packet, the form of which is defined in the Universal Serial Bus Specification Revision 2.0, Section 7.1.20.</p> <p><b>Note:</b> The text packet has a fixed format and must be loaded into the Endpoint 0 FIFO before the test mode is entered.</p> |
| 2              | R/W        | 0           | <p>Test_K<br/>(High-speed mode) The CPU sets this bit to enter the Test_K test mode. In this mode, the USB/DRD transmits a continuous K on the bus.</p>                                                                                                                                                                                                  |
| 1              | R/W        | 0           | <p>Test_J<br/>(High-speed mode) The CPU sets this bit to enter the Test_J test mode. In this mode, the USB/DRD transmits a continuous J on the bus.</p>                                                                                                                                                                                                  |
| 0              | R/W        | 0           | <p>Test_SE0_NAK<br/>(High-speed mode) The CPU sets this bit to enter the Test_SE0_NAK test mode. In this mode, the USB/DRD remains in High-speed mode but responds to any valid IN token with a NAK.</p>                                                                                                                                                 |

#### 8.8.5.9 0x0080 USB EP0 Control and Status Register (Default Value:0x0000\_0000)

| Offset: 0x0080 |            |             | Register Name: USB_CSR0                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                  |
| 31:25          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                            |
| 24             | W          | 0           | <p>FlushFIFO<br/>The CPU writes a '1' to this bit to flush the next packet to be transmitted/read from the Endpoint 0 FIFO. The FIFO pointer is reset, and the TxPktRdy/RxPktRdy bit (below) is cleared.</p> <p><b>Note:</b> (i)Writing '0' to this bit is ignored. (ii)Flush FIFO should only be used when TxPktRdy/RxPktRdy is set, at other times, it may cause data to be corrupted.</p> |
| 23             | W          | 0           | <p>ServicedSetupEnd<br/>The CPU writes a '1' to this bit to clear the SetupEnd bit. It is cleared automatically.</p>                                                                                                                                                                                                                                                                         |
| 22             | W          | 0           | <p>ServicedRxPktRdy<br/>The CPU writes a 1 to this bit to clear the RxPktRdy bit. It is cleared automatically.</p>                                                                                                                                                                                                                                                                           |
| 21             | W          | 0           | SendStall                                                                                                                                                                                                                                                                                                                                                                                    |

| Offset: 0x0080 |            |             | Register Name: USB_CSR0                                                                                                                                                                                                                                                                                                |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                            |
|                |            |             | <p>The CPU writes a '1' to this bit to terminate the current transaction. The STALL handshake will be transmitted and then this bit will be cleared automatically.</p> <p><b>Note:</b> The FIFO should be flushed before SendStall is set.</p>                                                                         |
| 20             | R          | 0           | <p>SetupEnd</p> <p>This bit will be set when a control transaction ends before the DataEnd bit has been set. An interrupt will be generated and the FIFO flushed at this time. The bit is cleared by the CPU writing a '1' to the ServicedSetupEnd bit.</p>                                                            |
| 19             | W          | 0           | <p>DataEnd</p> <p>The CPU sets this bit:</p> <ul style="list-style-type: none"> <li>When setting TxPktRdy for the last data packet.</li> <li>When clearing RxPktRdy after unloading the last data packet.</li> <li>When setting TxPktRdy for a zero length data packet.</li> </ul> <p>It is cleared automatically.</p> |
| 18             | R/W        | 0           | <p>SentStall</p> <p>This bit is set when a STALL handshake is transmitted. The CPU should clear this bit.</p>                                                                                                                                                                                                          |
| 17             | R/W        | 0           | <p>TxPktRdy</p> <p>The CPU sets this bit after loading a data packet into the FIFO. It is cleared automatically when a data packet has been transmitted. An interrupt is also generated at this point (if enabled).</p>                                                                                                |
| 16             | R          | 0           | <p>RxPktRdy</p> <p>This bit is set when a data packet has been received. An interrupt is generated (if enabled) when this bit is set. The CPU clears this bit by setting the ServicedRxPktRdy bit.</p>                                                                                                                 |
| 15:0           | /          | /           | /                                                                                                                                                                                                                                                                                                                      |

#### 8.8.5.10 0x0080 USB EP1 to 5 TX Control and Status Register (Default Value:0x0000\_0000)

| Offset: 0x0080 |            |             | Register Name: USB_TXCSR                                                                                                      |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                   |
| 31             | R/W        | 0           | <p>AutoSet</p> <p>If CPU sets this bit, TxPktRdy will be automatically set when data of maximum packet size (value in the</p> |

| Offset: 0x0080 |            |             | Register Name: USB_TXCSR                                                                                                                                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                |
|                |            |             | USB_TXMAXP) is loaded into the Tx FIFO. If a packet of less than the maximum packet size is loaded, then TxPktRdy will have to be set manually.<br><b>Note:</b> Should not be set for high-bandwidth Isochronous/Interrupt endpoints.                                                                                                                                                      |
| 30             | R/W        | 0           | ISO<br>The CPU sets this bit to enable the Tx endpoint for Isochronous transfers, and clears it to enable the Tx endpoint for Bulk or Interrupt transfers.<br><b>Note:</b> This is only has any effect in Peripheral mode. In Host mode, it always returns zero.                                                                                                                           |
| 29             | R/W        | 0           | Mode<br>The CPU sets this bit to enable the endpoint direction as Tx, and clears the bit to enable it as Rx.<br><b>Note:</b> This bit only has any affect where the same endpoint FIFO is used for Tx and Rx transactions.                                                                                                                                                                 |
| 28             | R/W        | 0           | DMAReqEnab<br>The CPU sets this bit to enable the DMA request for the Tx endpoint.                                                                                                                                                                                                                                                                                                         |
| 27             | R/W        | 0           | FrcDataTog<br>The CPU sets this bit to force the endpoint data toggle to switch and the data packet to be cleared from the FIFO, regardless of whether an ACK was received. This can be used by Interrupt Tx endpoints that are used to communicate rate feedback for Isochronous endpoints.                                                                                               |
| 26             | R/W        | 0           | DMAReqMode<br>The CPU sets this bit to select DMA Request Mode 1 and clears it to select DMA Request Mode 0.<br><b>Note:</b> This bit must not be cleared either before or in the same cycle as the above DMAReqEnab bit is cleared.                                                                                                                                                       |
| 25:24          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                          |
| 23             | R/W        | 0           | IncompTx<br>When the endpoint is being used for high-bandwidth Isochronous/Interrupt transfers, this bit is set to indicate where a large packet has been split into 2 or 3 packets for transmission but insufficient IN tokens have been received to send all the parts.<br><b>Note:</b> In anything other than a high-bandwidth transfer, this bit will always return 0. And writing '1' |

| Offset: 0x0080 |            |             | Register Name: USB_TXCSR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                |            |             | to this bit is ignored.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 22             | W          | 0           | <p>ClrDataTog<br/>The CPU writes a 1 to this bit to reset the endpoint data toggle to 0. It is cleared automatically.<br/><b>Note: Writing '0' to this bit is ignored.</b></p>                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 21             | R/W        | 0           | <p>SentStall<br/>This bit is set when a STALL handshake is transmitted. The FIFO is flushed and the TxPktRdy bit is cleared. The CPU should clear this bit.<br/><b>Note: Writing '1' to this bit is ignored.</b></p>                                                                                                                                                                                                                                                                                                                                                                                   |
| 20             | R/W        | 0           | <p>SendStall<br/>The CPU writes a 1 to this to issue a STALL handshake to an IN token. The CPU clears this bit to terminate the stall condition.<br/><b>Note: (i)The FIFO should be flushed before SendStall is set. (ii)This bit has no effect where the endpoint is being used for Isochronous transfers.</b></p>                                                                                                                                                                                                                                                                                    |
| 19             | W          | 0           | <p>FlushFIFO<br/>The CPU writes a 1 to this bit to flush the latest packet from the endpoint Tx FIFO. The FIFO pointer is reset, the TxPktRdy bit (below) is cleared and an interrupt is generated. May be set simultaneously with TxPktRdy to abort the packet that is currently being loaded into the FIFO.<br/><b>Note: (i)Writing '0' to this bit is ignored. (ii)Flush FIFO should only be used when TxPktRdy is set, at other times, it may cause data to be corrupted. Also note that, if the FIFO is double-buffered, FlushFIFO may need to be set twice to completely clear the FIFO.</b></p> |
| 18             | R/W        | 0           | <p>UnderRun<br/>The USB sets this bit if an IN token is received when the TxPktRdy bit not set. The CPU should clear this bit.<br/><b>Note: Writing '1' to this bit is ignored.</b></p>                                                                                                                                                                                                                                                                                                                                                                                                                |
| 17             | R/W        | 0           | <p>FIFONotEmpty<br/>The USB sets this bit when there is at least 1 packet in the Tx FIFO.<br/><b>Note: Writing '1' to this bit is ignored.</b></p>                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 16             | R/W        | 0           | <p>TxPktRdy<br/>The CPU sets this bit after loading a data packet into the FIFO. It is cleared automatically when a data</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

| Offset: 0x0080 |            |             | Register Name: USB_TXCSR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                |            |             | <p>packet has been transmitted. An interrupt is also generated at this point (if enabled). TxPktRdy is also automatically cleared prior to loading a second packet to a double buffered FIFO.</p> <p><b>Note:</b> Writing '0' to this bit is ignored.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 15:11          | R/W        | 0x00        | <p>PacketCount</p> <p>In the case of Bulk endpoints with the packet splitting option enabled, the Packet Count can be up to 32 and defines the maximum number of USB packets of specified payload into which a single data packet placed in the FIFO should be split, prior to transfer. If the packet splitting option is not enabled, Packet Count is not implemented.</p> <p>For Isochronous/Interrupt endpoints operating in High-speed mode and with the High-bandwidth option enabled, Packet Count may only either 2 or 3 (corresponding to bit 11 or bit 12 set, respectively) and it specifies the maximum number of such transactions that can be take place in a single microframe. If either bit 11 or bit 12 is non-zero, the USB/DRD will automatically split any data packet written to the FIFO into up to 2 or 3 USB packet, each containing the specified payload (or less). For Isochronous/Interrupt transfers in Full-speed mode or if High-bandwidth is not enabled, bit 11 and 12 are ignored.</p> <p><b>Note:</b> Value for this bits is (Packet Count - 1), but not Packet Count.</p> |
| 10:0           | R/W        | 0x000       | <p>MaximumPayload</p> <p>These bits define the maximum payload (in bytes) transmitted in a single transaction. The value set can be up to 1024 bytes but is subject to the constraints placed by the USB Specification on packet sizes for Bulk, Interrupt and Isochronous transfers in Full-speed and High-speed operations.</p> <p><b>Note:</b> (i) The value written to Maximum Payload (multiplied by Packet Count in the case of high-bandwidth Isochronous/Interrupt transfer) must match the value given in the wMaxPacketSize field of the Standard Endpoint Descriptor for the associated endpoint, a mismatch could cause</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

| Offset: 0x0080 |            |             | Register Name: USB_TXCSR                                                                                                                                                                                                                                    |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                 |
|                |            |             | unexpected result. (ii)The total amount of data represented by the value written to this register (Maximum payload × Packet Count) must not exceed the FIFO size for Tx endpoint, and should not exceed half the FIFO size if double-buffering is required. |

#### 8.8.5.11 0x0084 USB EP1 to 5 Rx Control and Status Register (Default Value:0x0000\_0000)

| Offset: 0x0084 |            |             | Register Name: USB_RXCSR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 31             | R/W        | 0           | <p>AutoClear</p> <p>If CPU sets this bit then the RxPktRdy will be automatically cleared when data of maximum packet size (value in the USB_TXMAXP) is unloaded from the Rx FIFO. If a packet of less than the maximum packet size is unloaded, then RxPktRdy will have to be cleared manually.</p> <p><b>Note:</b> Should not be set for high-bandwidth Isochronous endpoints.</p>                                                                                                                          |
| 30             | R/W        | 0           | <p>ISO</p> <p>The CPU sets this bit to enable the Rx endpoint for Isochronous transfers, and clears it to enable the Rx endpoint for Bulk or Interrupt transfers.</p>                                                                                                                                                                                                                                                                                                                                        |
| 29             | R/W        | 0           | <p>DMAReqEnab</p> <p>The CPU sets this bit to enable the DMA request for the Rx endpoint.</p>                                                                                                                                                                                                                                                                                                                                                                                                                |
| 28             | R/W        | 0           | <p>DisNyet_PIDError</p> <p>DisNyet</p> <p>Bulk/Interrupt Transactions: The CPU sets this bit to disable the sending of NYET handshakes. When set, all successfully received Rx packets are ACK'd including at the point at which the FIFO becomes full.</p> <p><b>Note:</b> This bit only has any affect in High-speed mode, in which mode it should be set for all Interrupt endpoints.</p> <p>PIDError</p> <p>ISO Transactions: The core sets this bit to indicate a PID error in the received packet.</p> |
| 27             | R/W        | 0           | <p>DMAReqMode</p> <p>The CPU sets this bit to select DMA Request Mode 1 and clears it to select DMA Request Mode 0.</p>                                                                                                                                                                                                                                                                                                                                                                                      |

| Offset: 0x0084 |            |             | Register Name: USB_RXCSR                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                |            |             | Note: This bit must not be cleared in the same cycle as the above RxPktRdy(or DMAReqEnab) bit is cleared.                                                                                                                                                                                                                                                                                                                                                             |
| 26:25          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 24             | R/W        | 0           | IncompRx<br>This bit will be set in a high-bandwidth Isochronous/Interrupt transfer if the packet received is incomplete. It will be cleared when RxPktRdy is cleared.<br><b>Note:</b> (i) Writing '1' to this bit is forbidden. (ii) In anything other than a high-bandwidth transfer, this bit will always return 0.                                                                                                                                                |
| 23             | W          | 0           | ClrDataTog<br>The CPU writes a '1' to this bit to reset the endpoint data toggle to 0. It is cleared automatically.<br><b>Note:</b> Writing '0' to this bit is ignored.                                                                                                                                                                                                                                                                                               |
| 22             | R/W        | 0           | SentStall<br>This bit is set when a STALL handshake is transmitted. The CPU should clear this bit.<br><b>Note:</b> Writing '1' to this bit is ignored.                                                                                                                                                                                                                                                                                                                |
| 21             | R/W        | 0           | SendStall<br>The CPU writes a '1' to this to issue a STALL handshake. The CPU clears this bit to terminate the stall condition.<br><b>Note:</b> (i)The FIFO should be flushed before SendStall is set. (ii)This bit has no effect where the endpoint is being used for Isochronous transfers.                                                                                                                                                                         |
| 20             | W          | 0           | FlushFIFO<br>The CPU writes a '1' to this bit to flush the next packet to be read from the endpoint Rx FIFO. The FIFO pointer is reset and the RxPktRdy bit (below) is cleared.<br><b>Note:</b> (i) Writing '0' to this bit is ignored. (ii) Flush FIFO should only be used when RxPktRdy is set, at other times, it may cause data to be corrupted. Also note that, if the FIFO is double-buffered, FlushFIFO may need to be set twice to completely clear the FIFO. |
| 19             | R          | 0           | DataError<br>This bit is set when RxPktRdy is set if the data packet has a CRC or bit-stuff error. It is cleared when                                                                                                                                                                                                                                                                                                                                                 |

| Offset: 0x0084 |            |             | Register Name: USB_RXCSR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                |            |             | RxPktRdy is cleared.<br><b>Note:</b> This bit is only valid when the endpoint is operating in ISO mode. In bulk mode, it always returns zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 18             | R/W        | 0           | OverRun<br>The USB sets this bit if an OUT token can not be loaded into the Rx FIFO. The CPU should clear this bit.<br><b>Note:</b> (i) Writing '1' to this bit is ignored. (ii) This bit is only valid when the endpoint is operating in ISO mode. In bulk mode, it always returns zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 17             | R          | 0           | FIFOFull<br>The USB sets this bit when no more packets can be loaded into the Rx FIFO.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 16             | R/W        | 0           | RxPktRdy<br>This bit is set when a data packet has been received. The CPU should clear this bit when the packet has been unloaded from the Rx FIFO. An interrupt is generated when the bit is set.<br><b>Note:</b> Writing '1' to this bit is ignored.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 15:11          | R/W        | 0x00        | PacketCount<br>In the case of Bulk endpoints with the packet combining option enabled, the Packet Count can be up to 32 and defines the maximum number of USB packets of specified payload which are to be combined into a single data packet within the FIFO. For Isochronous/Interrupt endpoints operating in High-speed mode and with the High-bandwidth option enabled, Packet Count may only either 2 or 3 (corresponding to bit 11 or bit 12 set, respectively) and it specifies the maximum number of such transactions that can be take place in a single microframe. If either bit 11 or bit 12 is non-zero, the USB/DRD will automatically combine the separate USB packets received in any microframe into a single packet within the Rx FIFO. For Isochronous/Interrupt transfers in Full-speed mode or if High-bandwidth is not enabled, bit 11 and 12 are ignored.<br><b>Note:</b> Value for this bits is (Packet Count - 1), but not Packet Count. |
| 10:0           | R/W        | 0x000       | MaximumPayload                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

| Offset: 0x0084 |            |             | Register Name: USB_RXCSR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                |            |             | <p>These bits define the maximum payload (in bytes) transmitted in a single transaction. The value set can be up to 1024 bytes but is subject to the constraints placed by the USB Specification on packet sizes for Bulk, Interrupt and Isochronous transfers in Full-speed and High-speed operations.</p> <p><b>Note:</b> (i) The value written to Maximum Payload (multiplied by Packet Count in the case of high-bandwidth Isochronous/Interrupt transfer) must match the value given in the wMaxPacketSize field of the Standard Endpoint Descriptor for the associated endpoint, a mismatch could cause unexpected result. (ii) The total amount of data represented by the value written to this register (Maximum payload × Packet Count) must not exceed the FIFO size for OUT endpoint, and should not exceed half the FIFO size if double-buffering is required.</p> |

#### 8.8.5.12 0x0088 USB EP0 Rx Counter Register (Default Value:0x0000\_0000)

| Offset: 0x0088 |            |             | Register Name: USB_COUNT0                                                                                                                                                                                                                               |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                             |
| 31:7           | /          | /           | /                                                                                                                                                                                                                                                       |
| 6:0            | R          | 0x00        | <p>RxCount0<br/>Endpoint 0 Rx Count<br/>These bits indicate the number of received data bytes in the Endpoint 0 FIFO.</p> <p><b>Note:</b> The value returned changes as the FIFO is unloaded and is only valid while RxPktRdy (of USB_CSR0) is set.</p> |

#### 8.8.5.13 0x0088 USB EP1 to 5 Rx Counter Register (Default Value:0x0000\_0000)

| Offset: 0x0088 |            |             | Register Name: USB_RXCOUNT                                                                                                                                                |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                               |
| 31:16          | R/W        | 0x0000      | <p>RqPktCount<br/>Sets the number of packets of size MaxP that are to be transferred in a block transfer.</p> <p><b>Note:</b> Only used in Host mode when AutoReq (of</p> |

| Offset: 0x0088 |            |             | Register Name: USB_RXCOUNT                                                                                                                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                             |
|                |            |             | USB_RXCSR) is set. Has no effect in Peripheral mode or AutoReq is not set.                                                                                                                                                                                                                                                                                                              |
| 15:13          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                       |
| 12:0           | R          | 0x0000      | <p>RxCount<br/>Endpoint Rx Count<br/>These bits hold the number of data bytes in the packet currently in line to be read from the Rx FIFO. If the packet was transmitted as multiple bulk packets, the number given will be for the combined packet.</p> <p><b>Note:</b> The value returned changes as the FIFO is unloaded and is only valid while RxPktRdy (of USB_RXCSR) is set.</p> |

#### 8.8.5.14 0x0090 USB EP1 to 5 TxFIFO Setting Register (Default Value:0x0000\_0000)

| Offset: 0x0090 |            |             | Register Name: USB_TXFIFO                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                    |
| 31:29          | /          | /           | /                                                                                                                                                                                                                                                                                                                                              |
| 28:16          | R/W        | 0x0000      | <p>AD<br/>AD [12:0]<br/>Start address of the endpoint FIFO is in units of 8 bytes, and it equals (AD[12:0]*8).</p>                                                                                                                                                                                                                             |
| 15:5           | /          | /           | /                                                                                                                                                                                                                                                                                                                                              |
| 4              | R/W        | 0           | <p>DPB<br/>Defines whether double-packet buffering supported. When '1', double-packet buffering is supported. When '0', only single-packet buffering is supported.</p>                                                                                                                                                                         |
| 3:0            | R/W        | 0x0         | <p>SZ<br/>SZ [3:0]<br/>Maximum packet size to be allowed for (<i>before any</i> splitting within the FIFO of Bulk/High-Bandwidth packets prior to transmission) is <math>2^{(SZ[3:0]+3)}</math> bytes, and the valid values for SZ [3:0] are 0x0–0x09. If DPB=0, the FIFO will also this size; if DPB=1, the FIFO will be twice this size.</p> |

#### 8.8.5.15 0x0094 USB EP1 to 5 RxFIFO Setting Register (Default Value:0x0000\_0000)

|                |                           |
|----------------|---------------------------|
| Offset: 0x0094 | Register Name: USB_RXFIFO |
|----------------|---------------------------|

| Bit   | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                         |
|-------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:29 | /          | /           | /                                                                                                                                                                                                                                                                                                                   |
| 28:16 | R/W        | 0x0000      | AD<br>AD [12:0]<br>Start address of the endpoint FIFO is in units of 8 bytes, and it equals (AD[12:0]*8).                                                                                                                                                                                                           |
| 15:5  | /          | /           | /                                                                                                                                                                                                                                                                                                                   |
| 4     | R/W        | 0           | DPB<br>Defines whether double-packet buffering supported.<br>When '1', double-packet buffering is supported.<br>When '0', only single-packet buffering is supported.                                                                                                                                                |
| 3:0   | R/W        | 0x0         | SZ<br>SZ [3:0]<br>Maximum packet size to be allowed for (before any splitting within the FIFO of Bulk/High-Bandwidth packets prior to transmission) is $2^{(SZ[3:0]+3)}$ bytes, and the valid values for SZ [3:0] are 0x0–0x09. If DPB=0, the FIFO will also this size; if DPB=1, the FIFO will be twice this size. |

#### 8.8.5.16 0x0098 USB Function Address Register (Default Value:0x0000\_0000)

| Offset: 0x0098 |            |             | Register Name: USB_FADDR                                                                                                                                                                 |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                              |
| 31:7           | /          | /           | /                                                                                                                                                                                        |
| 6:0            | RW         | 0x00        | FADDR<br>The function address in peripheral mode. This field is reset to zero after a USB bus reset, and should be updated by software after Set_Address Command during USB enumeration. |

#### 8.8.5.17 0x0400 USB Interface Status and Control Register (Default Value:0x0000\_0000)

| Offset: 0x0400 |            |             | Register Name: USB_ISCR                                           |
|----------------|------------|-------------|-------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                       |
| 31             | /          | 0           | /                                                                 |
| 30             | R          | -           | VBUSLS<br>USB VBUS Valid Status detected from Line State          |
| 29             | R          | -           | VBUSEX<br>USB VBUS Valid Status detected from external VBUS input |
| 28             | R          | -           | INDEX                                                             |

| Offset: 0x0400 |            |             | Register Name: USB_ISCR                                                                                                                                                                                                   |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                               |
|                |            |             | USB ID Status detected from external ID input                                                                                                                                                                             |
| 27:26          | R          | -           | LS<br>USB Line Status<br>[27]—DM<br>[26]—DP                                                                                                                                                                               |
| 25             | R          | -           | VBUS<br>USB VBUS Status merged from both internal and external                                                                                                                                                            |
| 24             | R          | -           | ID<br>USB ID Status merged from both internal and external                                                                                                                                                                |
| 23:18          | /          | 0           | /                                                                                                                                                                                                                         |
| 17             | R/W        | 0           | IDPullupEn<br>ID pull up enable<br>0: disable<br>1: enable ID pull up                                                                                                                                                     |
| 16             | R/W        | 0           | DataPullupEn<br>DP/DM pull up enable<br>0: DP/DM pull up disable<br>1: DP/DM pull up enable                                                                                                                               |
| 15:14          | R/W        | 0           | ForceID<br>Force ID<br>0x: use external ID Status<br>10: force ID to LOW<br>11: force ID to HIGH                                                                                                                          |
| 13:12          | R/W        | 0           | ForceVBUSt<br>Force VBUS Valid<br>0x: use external VBUS Valid Status from VBUS Input or Line State<br>10: Force VBUS Valid to LOW<br>11: Force VBUS Valid to HIGH                                                         |
| 11:10          | R/W        | 0           | VBUSSEL<br>External VBUS Valid Source Select<br>0x: External VBUS Valid detected from VBUS Input<br>10: External VBUS Valid detected from DP/DM Input<br>11: External VBUS Valid detected from either VBUS or DP/DM input |
| 9:8            | /          | 0           | /                                                                                                                                                                                                                         |
| 7              | R/W        | 0           | WakeupEn<br>USB Wakeup Enable<br>0: Disable                                                                                                                                                                               |

| Offset: 0x0400 |            |             | Register Name: USB_ISCR                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                              |
|                |            |             | 1: Enable                                                                                                                                                                                                                                                                |
| 6              | R/W        | 0           | VBUSCDS<br>VBUS Input Change Detect Status<br>This bit is set by hardware after VBUS input changed when VBUS change detect is enable. Writing '1' will clear this bit.                                                                                                   |
| 5              | R/W        | 0           | IDCDS<br>ID Input Change Detect Status<br>This bit is set by hardware after ID input changed when ID change detect is enable. Writing '1' will clear this bit.                                                                                                           |
| 4              | R/W        | 0           | DATAACDS<br>DP/DM Input Change Detect Status<br>This bit is set by hardware after DP/DM input changed when DP/DM change detect is enable. Writing '1' will clear this bit.                                                                                               |
| 3              | R/W        | 0           | Wakeupe<br>USB Wakeup IRQ Enable<br>1: Enable USB Wakeup IRQ<br>0: Disable USB Wakeup IRQ<br>If this bit is set to zero, an USB wakeup event (VBUS/ID/DP/DM change) will generate an USB wakeup request to wakeup the system, but not generate an USB wakeup IRQ to CPU. |
| 2              | R/W        | 0           | VBUSCDE<br>VBUS Input Change Detect enable<br>0: Disable; 1: Enable                                                                                                                                                                                                      |
| 1              | RW         | 0           | IDCDE<br>ID Input Change Detect enable<br>0: Disable; 1: Enable                                                                                                                                                                                                          |
| 0              | R/W        | 0           | DATAACDE<br>DP/DM Input Change Detect enable<br>0: Disable; 1: Enable                                                                                                                                                                                                    |

#### 8.8.5.18 0x0410 USB PHY Control Register (Default Value:0x0000\_0008)

| Offset: 0x0410 |            |             | Register Name: USB_PHY_CTL |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:9           | /          | /           | /                          |
| 8              | R/W        | 0           | VREGBYPASS                 |
| 7              | R/W        | 0           | LOOPBACKENB                |

| Offset: 0x0410 |            |             | Register Name: USB_PHY_CTL                                       |
|----------------|------------|-------------|------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                      |
| 6              | R/W        | 0           | IDPULLUP                                                         |
| 5              | R/W        | 0           | VBUSVLDEXT                                                       |
| 4              | R/W        | 1           | VBUSVLDEXTSEL                                                    |
| 3              | R/W        | 1           | SIDDQ<br>1: Write 1 to disable phy.<br>0: Write 0 to enable phy. |
| 2              | R/W        | 0           | COMMONN                                                          |
| 1:0            | R/W        | 0           | VATESTENB                                                        |

#### 8.8.5.19 0x0414 USB PHY Test Register (Default Value:0x0000\_0000)

| Offset: 0x0414 |            |             | Register Name: USB_PHY_TEST |
|----------------|------------|-------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                 |
| 31:15          | /          | /           | /                           |
| 14             | R/W        | 0x0         | TESTBURNIN                  |
| 13             | R/W        | 0x0         | TESTDATAOUTSEL              |
| 12             | R/W        | 0x0         | TESTCLK                     |
| 11:8           | R/W        | 0x0         | TESTADDR                    |
| 7:0            | R/W        | 0x0         | TESTDATAIN                  |

#### 8.8.5.20 0x0418 USB PHY Tune Register (Default Value:0x05B3\_33D4)

| Offset: 0x0418 |            |             | Register Name: USB_PHY_TUNE |
|----------------|------------|-------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                 |
| 31:28          | /          | /           | /                           |
| 27:26          | R/W        | 0x1         | VDATREFTUNE[1:0]            |
| 25:23          | R/W        | 0x3         | COMPDISTUNE[2:0]            |
| 22:20          | R/W        | 0x3         | SQRXTUNE[2:0]               |
| 19             | R/W        | 0x0         | TXPREEMPPULSETUNE           |
| 18:16          | R/W        | 0x3         | OTGTUNE[2:0]                |
| 15:12          | R/W        | 0x3         | TXFSLSTUNE[3:0]             |
| 11:8           | R/W        | 0x3         | TXVREFTUNE[3:0]             |
| 7:6            | R/W        | 0x3         | TXHSXVTUNE[1:0]             |
| 5:4            | R/W        | 0x1         | TXRISETUNE[1:0]             |
| 3:2            | R/W        | 0x1         | TXRESTUNE[1:0]              |
| 1:0            | R/W        | 0x0         | TXPREEMPAMPTUNE[1:0]        |

## 8.8.5.21 0x0420 USB PHY Select Register (Default Value:0x0000\_0001)

| Offset: 0x0420 |            |             | Register Name: USB_PHY_SEL                                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                 |
| 31:1           | /          | /           | Reserved                                                                    |
| 0              | R/W        | 0x1         | OTG_SEL<br>1: Phy is connected to OTG SIE<br>0: Phy is connected to HCI SIE |

## 8.8.5.22 0x0424 USB PHY Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0424 |            |             | Register Name: USB_PHY_STA |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:4           | /          | /           | /                          |
| 3:0            | R          | 0           | TESTDATAOUT                |

## 8.8.5.23 0x0500 USB DMA Interrupt Enable Register (Default Value:0x0000\_0000)

| Offset: 0x0500 |            |             | Register Name: USB_DMA_INTE                                                                   |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                   |
| 31:8           | /          | /           | Reserved                                                                                      |
| 7              | R/W        | 0x0         | USB_DMA7_PKG_INT_EN<br>DMA7 Package End Transfer Interrupt Enable<br>0: Disable<br>1: Enable. |
| 6              | R/W        | 0x0         | USB_DMA6_PKG_INT_EN<br>DMA6 Package End Transfer Interrupt Enable<br>0: Disable<br>1: Enable. |
| 5              | R/W        | 0x0         | USB_DMA5_PKG_INT_EN<br>DMA5 Package End Transfer Interrupt Enable<br>0: Disable<br>1: Enable. |
| 4              | R/W        | 0x0         | USB_DMA4_PKG_INT_EN<br>DMA4 Package End Transfer Interrupt Enable<br>0: Disable<br>1: Enable. |
| 3              | R/W        | 0x0         | USB_DMA3_PKG_INT_EN<br>DMA3 Package End Transfer Interrupt Enable<br>0: Disable<br>1: Enable. |
| 2              | R/W        | 0x0         | USB_DMA2_PKG_INT_EN                                                                           |

| Offset: 0x0500 |            |             | Register Name: USB_DMA_INTE                                                                   |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                   |
|                |            |             | DMA2 Package End Transfer Interrupt Enable<br>0: Disable<br>1: Enable.                        |
| 1              | R/W        | 0x0         | USB_DMA1_PKG_INT_EN<br>DMA1 Package End Transfer Interrupt Enable<br>0: Disable<br>1: Enable. |
| 0              | R/W        | 0x0         | USB_DMA0_PKG_INT_EN<br>DMA0 Package End Transfer Interrupt Enable<br>0: Disable<br>1: Enable. |

#### 8.8.5.24 0x0504 USB DMA Interrupt Status Register (Default Value:0x0000\_0000)

| Offset: 0x0504 |            |             | Register Name: USB_DMA_INTS                                                                                                        |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                        |
| 31:8           | /          | /           | Reserved                                                                                                                           |
| 7              | R/W        | 0x0         | USB_DMA7_PKG_INT_STA<br>DMA7 Package End Transfer Interrupt Status. Set 1 to the bit will clean it.<br>0: No effect<br>1: Pending. |
| 6              | R/W        | 0x0         | USB_DMA6_PKG_INT_STA<br>DMA6 Package End Transfer Interrupt Status. Set 1 to the bit will clean it.<br>0: No effect<br>1: Pending. |
| 5              | R/W        | 0x0         | USB_DMA5_PKG_INT_STA<br>DMA5 Package End Transfer Interrupt Status. Set 1 to the bit will clean it.<br>0: No effect<br>1: Pending. |
| 4              | R/W        | 0x0         | USB_DMA4_PKG_INT_STA<br>DMA4 Package End Transfer Interrupt Status. Set 1 to the bit will clean it.<br>0: No effect<br>1: Pending. |
| 3              | R/W        | 0x0         | USB_DMA3_PKG_INT_STA<br>DMA3 Package End Transfer Interrupt Status. Set 1 to the bit will clean it.<br>0: No effect                |

| Offset: 0x0504 |            |             | Register Name: USB_DMA_INTS                                                                                                        |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                        |
|                |            |             | 1: Pending.                                                                                                                        |
| 2              | R/W        | 0x0         | USB_DMA2_PKG_INT_STA<br>DMA2 Package End Transfer Interrupt Status. Set 1 to the bit will clean it.<br>0: No effect<br>1: Pending. |
| 1              | R/W        | 0x0         | USB_DMA1_PKG_INT_STA<br>DMA1 Package End Transfer Interrupt Status. Set 1 to the bit will clean it.<br>0: No effect<br>1: Pending. |
| 0              | R/W        | 0x0         | USB_DMA0_PKG_INT_STA<br>DMA0 Package End Transfer Interrupt Status. Set 1 to the bit will clean it.<br>0: No effect<br>1: Pending. |

#### 8.8.5.25 0x0540+N\*0x10(N=0-7) USB DMA Channel Configuration Register (Default Value:0x0000\_0000)

| Offset: 0x0540+N*0x10(N=0-7) |            |             | Register Name: USB_DMA_CHAN_CFG                                                                                                                                                                                                                                                                |
|------------------------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                          | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                    |
| 31                           | R/W        | 0x0         | DMA_EN<br>DMA Channel Enable<br>If set to 1, DMA will start the data transfer between the source and the destination. The bit will hold on until the DMA finished. It will be cleared automatically.<br>Set 0 to this bit will stop the corresponding DMA channel and reset its state machine. |
| 30:27                        | /          | /           | /                                                                                                                                                                                                                                                                                              |
| 26:16                        | R/W        | 0x0         | DMA_BST_LEN<br>DMA Burst Length<br>The value setting on this field should be equated to the USB max packet length of the corresponding endpoint.                                                                                                                                               |
| 15:5                         | /          | /           | /                                                                                                                                                                                                                                                                                              |
| 4                            | R/W        | 0x0         | DMA_DIR<br>DMA Transfer Direction<br>0: SDRAM to USB FIFO<br>1: USB FIFO to SDRAM                                                                                                                                                                                                              |
| 3:0                          | R/W        | 0x0         | DMA_FOR_EP                                                                                                                                                                                                                                                                                     |

| Offset: 0x0540+N*0x10(N=0-7) |            |             | Register Name: USB_DMA_CHAN_CFG                                                                                               |
|------------------------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------|
| Bit                          | Read/Write | Default/Hex | Description                                                                                                                   |
|                              |            |             | DMA Channel for Endpoint<br>The Endpoint number setting on this field selects the DMA channel for the corresponding endpoint. |

#### 8.8.5.26 0x0544+N\*0x10(N=0-7) USB DMA SDRAM Start Address Register (Default Value:0x0000\_0000)

| Offset: 0x0544+N*0x10(N=0-7) |            |             | Register Name: USB_DMA_SDRAM_ADD                                                                                                      |
|------------------------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------|
| Bit                          | Read/Write | Default/Hex | Description                                                                                                                           |
| 31:0                         | R/W        | 0x0         | DMA_SDRAM_STR_ADDR<br>DMA SDRAM Start Address<br>The SDRAM start address for the DMA channel transfer between the SDRAM and USB FIFO. |

#### 8.8.5.27 0x0548+N\*0x10(N=0-7) USB DMA Byte Counter Register (Default Value:0x0000\_0000)

| Offset: 0x0548+N*0x10(N=0-7) |            |             | Register Name: USB_DMA_BC  |
|------------------------------|------------|-------------|----------------------------|
| Bit                          | Read/Write | Default/Hex | Description                |
| 31:18                        | /          | /           | /                          |
| 17:0                         | R/W        | 0x0         | DMA_BC<br>DMA Byte Counter |

#### 8.8.5.28 0x054C+N\*0x10(N=0-7) USB DMA RESIDUAL Byte Counter Register (Default Value:0x0000\_0000)

| Offset: 0x054C+N*0x10(N=0-7) |            |             | Register Name: USB_DMA_RESIDUAL_BC                                                                               |
|------------------------------|------------|-------------|------------------------------------------------------------------------------------------------------------------|
| Bit                          | Read/Write | Default/Hex | Description                                                                                                      |
| 31:18                        | /          | /           | /                                                                                                                |
| 17:0                         | R/W        | 0x0         | DMA_RESIDUAL_BC<br>DMA Residual Byte Counter<br>This field contains the residual byte count in current transfer. |

### 8.8.6 EHCI Register Description

#### 8.8.6.1 0x0000 EHCI Identification Register (Default Value:0x10)

| Offset:0x0000 |            |             | Register Name: E_CAPLENGTH                                         |
|---------------|------------|-------------|--------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                        |
| 7:0           | R          | 0x10        | CAPLENGTH<br>The value in these bits indicates an offset to add to |

| Offset:0x0000 |            |             | Register Name: E_CAPLENGTH                                             |
|---------------|------------|-------------|------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                            |
|               |            |             | register base to find the beginning of the Operational Register Space. |

#### 8.8.6.2 0x0002 EHCI Host Interface Version Number Register (Default Value:0x0100)

| Offset: 0x0002 |            |             | Register Name: E_HCIVERSION                                                                                                                                                                                                                                    |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                    |
| 15:0           | R          | 0x0100      | HCIVERSION<br>This is a 16-bits register containing a BCD encoding of the EHCI revision number supported by this host controller. The most significant byte of this register represents a major revision and the least significant byte is the minor revision. |

#### 8.8.6.3 0x0004 EHCI Host Control Structural Parameter Register (Default Value:0x0000\_1101)

| Offset: 0x0004 |            |             | Register Name: E_HCSPARAMS                                                                                                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                  |
| 31:24          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                            |
| 23:20          | R          | 0           | Debug Port Number<br>This register identifies which of the host controller ports is the debug port. The value is the port number (one based) of the debug port.<br>This field will always be '0'.                                                                                                                                                            |
| 19:16          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                            |
| 15:12          | R          | 1           | Number of Companion Controller (N_CC)<br>This field indicates the number of companion controllers associated with this USB2.0 host controller. A zero in this field indicates there are no companion host controllers. And a value larger than zero in this field indicates there are companion USB1.1 host controller(s).<br>This field will always be '0'. |
| 11:8           | R          | 1           | Number of Port per Companion Controller(N_PCC)<br>This field indicates the number of ports supported per companion host controller host controller. It is used to indicate the port routing configuration to system software.<br>This field will always fix with '0'.                                                                                        |
| 7              | R          | 0           | Port Routing Rules                                                                                                                                                                                                                                                                                                                                           |

| Offset: 0x0004 |                                                                                                                                                                                         |             | Register Name: E_HCSPARAMS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write                                                                                                                                                                              | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |
|                |                                                                                                                                                                                         |             | <p>This field indicates the method used by this implementation for how all ports are mapped to companion controllers. The value of this field has the following interpretation:</p> <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>The first N_PCC ports are routed to the lowest numbered function companion host controller, the next N_PCC port are routed to the next lowest function companion controller, and so on.</td></tr> <tr> <td>1</td><td>The port routing is explicitly enumerated by the first N_PORTS elements of the HCSP-PORTTOUTE array.</td></tr> </tbody> </table> <p>This field will always be '0'.</p> | Value | Meaning | 0 | The first N_PCC ports are routed to the lowest numbered function companion host controller, the next N_PCC port are routed to the next lowest function companion controller, and so on. | 1 | The port routing is explicitly enumerated by the first N_PORTS elements of the HCSP-PORTTOUTE array. |
| Value          | Meaning                                                                                                                                                                                 |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |
| 0              | The first N_PCC ports are routed to the lowest numbered function companion host controller, the next N_PCC port are routed to the next lowest function companion controller, and so on. |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |
| 1              | The port routing is explicitly enumerated by the first N_PORTS elements of the HCSP-PORTTOUTE array.                                                                                    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |
| 6:4            | /                                                                                                                                                                                       | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |
| 3:0            | R                                                                                                                                                                                       | 1           | <p>N_PORTS</p> <p>This field specifies the number of physical downstream ports implemented on this host controller. The value of this field determines how many port registers are addressable in the Operational Register Space. Valid values are in the range of 0x1 to 0x0f.</p> <p>This field is always 1.</p>                                                                                                                                                                                                                                                                                                                                                                      |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |

#### 8.8.6.4 0x0008 EHCI Host Control Capability Parameter Register (Default Value:0x0000\_a026)

| Offset: 0x0008 |            |             | Register Name: E_HCCPARAMS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 31:16          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 15:8           | R          | 0xa0        | <p>EHCI Extended Capabilities Pointer (EECP)</p> <p>This optional field indicates the existence of a capabilities list. A value of 00b indicates no extended capabilities are implemented. A non-zero value in this register indicates the offset in PCI configuration space of the first EHCI extended capability. The pointer value must be 40h or greater if implemented to maintain consistency of the PCI header defined for this class of device.</p> <p>The value of this field is always '00b'.</p> |

| Offset: 0x0008 |            |             | Register Name: E_HCCPARAMS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 7:4            | R          | 0x2         | <p>Isochronous Scheduling Threshold<br/>                     This field indicates, relative to the current position of the executing host controller, where software can reliably update the isochronous schedule.<br/>                     When bit[7] is zero, the value of the least significant 3 bits indicates the number of micro-frames a host controller can hold a set of isochronous data structures(one or more) before flushing the state.<br/>                     When bit[7] is a one, then host software assumes the host controller may cache an isochronous data structure for an entire frame.</p>           |
| 3              | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 2              | R          | 1           | <p>Asynchronous Schedule Park Capability<br/>                     If this bit is set to a one, then the host controller supports the park feature for high-speed queue heads in the Asynchronous Schedule. The feature can be disabled or enabled and set to a specific level by using the Asynchronous Schedule Park Mode Enable and Asynchronous Schedule Park Mode Count fields in the USBCMD register.</p>                                                                                                                                                                                                                   |
| 1              | R          | 1           | <p>Programmable Frame List Flag<br/>                     If this bit is set to a zero, then system software must use a frame list length of 1024 elements with this host controller.The USBCMD register Frame List Size field is a read-only register and should be set to zero.<br/>                     If set to 1,then system software can specify and use the frame list in the USBCMD register Frame List Size field to configure the host controller.<br/>                     The frame list must always aligned on a 4K page boundary.This requirement ensures that the frame list is always physically contiguous.</p> |
| 0              | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

#### 8.8.6.5 0x000C EHCI Companion Port Route Description (Default Value:0x0000\_0000)

| Offset: 0x000C |            |             | Register Name: E_HCSPPORTROUTE                                                                         |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                            |
| 31:0           | R          | 0x0         | <p>HCSP-PORTROUTE<br/>                     This optional field is valid only if Port Routing Rules</p> |

| Offset: 0x000C |            |             | Register Name: E_HCSPPORTROUTE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                |            |             | <p>field in HCSPARAMS register is set to a one. This field is used to allow a host controller implementation to explicitly describe to which companion host controller each implemented port is mapped. This field is a 15-element nibble array (each 4 bit is one array element). Each array location corresponds one-to-one with a physical port provided by the host controller (e.g. PORTROUTE [0] corresponds to the first PORTSC port, PORTROUTE [1] to the second PORTSC port, etc.). The value of each element indicates to which of the companion host controllers this port is routed. Only the first N_PORTS elements have valid information. A value of zero indicates that the port is routed to the lowest numbered function companion host controller. A value of one indicates that the port is routed to the next lowest numbered function companion host controller, and so on.</p> |

#### 8.8.6.6 0x0010 EHCI USB Command Register (Default Value:0x0008\_0b00)

| Offset: 0x0010 |                                         |             | Register Name: USBCMD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
|----------------|-----------------------------------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|----------------------------|------|----------|------|---------------|------|---------------|------|---------------|------|-----------------------------------------|------|---------------------|------|---------------------|------|---------------------|
| Bit            | Read/Write                              | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 31:24          | /                                       | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 23:16          | R/W                                     | 0x08        | <p>Interrupt Threshold Control<br/>         The value in this field is used by system software to select the maximum rate at which the host controller will issue interrupts. The only valid values are defined below:</p> <table border="1"> <thead> <tr> <th>Value</th> <th>Minimum Interrupt Interval</th> </tr> </thead> <tbody> <tr> <td>0x00</td> <td>Reserved</td> </tr> <tr> <td>0x01</td> <td>1 micro-frame</td> </tr> <tr> <td>0x02</td> <td>2 micro-frame</td> </tr> <tr> <td>0x04</td> <td>4 micro-frame</td> </tr> <tr> <td>0x08</td> <td>8 micro-frame(default, equates to 1 MS)</td> </tr> <tr> <td>0x10</td> <td>16 micro-frame(2ms)</td> </tr> <tr> <td>0x20</td> <td>32 micro-frame(4ms)</td> </tr> <tr> <td>0x40</td> <td>64 micro-frame(8ms)</td> </tr> </tbody> </table> <p>Any other value in this register yields undefined</p> | Value | Minimum Interrupt Interval | 0x00 | Reserved | 0x01 | 1 micro-frame | 0x02 | 2 micro-frame | 0x04 | 4 micro-frame | 0x08 | 8 micro-frame(default, equates to 1 MS) | 0x10 | 16 micro-frame(2ms) | 0x20 | 32 micro-frame(4ms) | 0x40 | 64 micro-frame(8ms) |
| Value          | Minimum Interrupt Interval              |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x00           | Reserved                                |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x01           | 1 micro-frame                           |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x02           | 2 micro-frame                           |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x04           | 4 micro-frame                           |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x08           | 8 micro-frame(default, equates to 1 MS) |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x10           | 16 micro-frame(2ms)                     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x20           | 32 micro-frame(4ms)                     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x40           | 64 micro-frame(8ms)                     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |

| Offset: 0x0010 |            |             | Register Name: USBCMD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                |            |             | <p>results.</p> <p>The default value in this field is 0x08.</p> <p>Software modifications to this bit while HC Halted bit is equal to zero results in undefined behavior.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 15:12          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 11             | R          | 1           | <p>Asynchronous Schedule Park Mode Enable(OPTIONAL)</p> <p>If the Asynchronous Park Capability bit in the HCCPARAMS register is a one, then this bit defaults to a 1 and is R/W. Otherwise the bit must be a zero and is Read Only. Software uses this bit to enable or disable Park mode. When this bit is one, Park mode is enabled. When this bit is zero, Park mode is disabled.</p>                                                                                                                                                                                                                                                                          |
| 10             | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 9:8            | R          | 0x3         | <p>Asynchronous Schedule Park Mode Count(OPTIONAL)</p> <p>Asynchronous Park Capability bit in the HCCPARAMS register is a one,</p> <p>Then this field defaults to 0x3 and is W/R. Otherwise it defaults to zero and is R. It contains a count of the number of successive transactions the host controller is allowed to execute from a high-speed queue head on the Asynchronous schedule before continuing traversal of the Asynchronous schedule.</p> <p>Valid value are 0x1 to 0x3. Software must not write a zero to this bit when Park Mode Enable is a one as it will result in undefined behavior.</p>                                                    |
| 7              | R/W        | 0           | <p>Light Host Controller Reset(OPTIONAL)</p> <p>This control bit is not required.</p> <p>If implemented, it allows the driver to reset the EHCI controller without affecting the state of the ports or relationship to the companion host controllers. For example, the PORSTC registers should not be reset to their default values and the CF bit setting should not go to zero (retaining port ownership relationships).</p> <p>A host software read of this bit as zero indicates the Light Host Controller Reset has completed and it is safe for software to re-initialize the host controller. A host software read of this bit as a one indicates the</p> |

| Offset: 0x0010 |                                                                    |             | Register Name: USBCMD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |           |         |   |                                           |   |                                                                    |
|----------------|--------------------------------------------------------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|---------|---|-------------------------------------------|---|--------------------------------------------------------------------|
| Bit            | Read/Write                                                         | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |           |         |   |                                           |   |                                                                    |
|                |                                                                    |             | Light Host                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |           |         |   |                                           |   |                                                                    |
| 6              | R/W                                                                | 0           | <p>Interrupt on Async Advance Doorbell<br/>This bit is used as a doorbell by software to tell the host controller to issue an interrupt the next time it advances asynchronous schedule. Software must write a 1 to this bit to ring the doorbell. When the host controller has evicted all appropriate cached schedule state, it sets the Interrupt on Async Advance status bit in the USBSTS. if the Interrupt on Async Advance Enable bit in the USBINTR register is a one then the host controller will assert an interrupt at the next interrupt threshold.</p> <p>The host controller sets this bit to a zero after it has set the Interrupt on Async Advance status bit in the USBSTS register to a one.</p> <p>Software should not write a one to this bit when the asynchronous schedule is disabled. Doing so will yield undefined results.</p> |           |         |   |                                           |   |                                                                    |
| 5              | R/W                                                                | 0           | <p>Asynchronous Schedule Enable<br/>This bit controls whether the host controller skips processing the Asynchronous Schedule. Values mean:</p> <table border="1"> <thead> <tr> <th>Bit Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Do not process the Asynchronous Schedule.</td></tr> <tr> <td>1</td><td>Use the ASYNLISTADDR register to access the Asynchronous Schedule.</td></tr> </tbody> </table> <p>The default value of this field is '0b'.</p>                                                                                                                                                                                                                                                                                                                                                                          | Bit Value | Meaning | 0 | Do not process the Asynchronous Schedule. | 1 | Use the ASYNLISTADDR register to access the Asynchronous Schedule. |
| Bit Value      | Meaning                                                            |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |           |         |   |                                           |   |                                                                    |
| 0              | Do not process the Asynchronous Schedule.                          |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |           |         |   |                                           |   |                                                                    |
| 1              | Use the ASYNLISTADDR register to access the Asynchronous Schedule. |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |           |         |   |                                           |   |                                                                    |
| 4              | R/W                                                                | 0           | <p>Periodic Schedule Enable<br/>This bit controls whether the host controller skips processing the Periodic Schedule. Values mean:</p> <table border="1"> <thead> <tr> <th>Bit Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Do not process the Periodic Schedule.</td></tr> <tr> <td>1</td><td>Use the PERIODICLISTBASE register to access the Periodic Schedule.</td></tr> </tbody> </table> <p>The default value of this field is '0b'.</p>                                                                                                                                                                                                                                                                                                                                                                                      | Bit Value | Meaning | 0 | Do not process the Periodic Schedule.     | 1 | Use the PERIODICLISTBASE register to access the Periodic Schedule. |
| Bit Value      | Meaning                                                            |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |           |         |   |                                           |   |                                                                    |
| 0              | Do not process the Periodic Schedule.                              |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |           |         |   |                                           |   |                                                                    |
| 1              | Use the PERIODICLISTBASE register to access the Periodic Schedule. |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |           |         |   |                                           |   |                                                                    |
| 3:2            | R/W                                                                | 0           | <p>Frame List Size<br/>This field is R/W only if Programmable Frame List Flag in the HCCPARAMS registers is set to a one. This</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |           |         |   |                                           |   |                                                                    |

| Offset: 0x0010 |                                                           |             | Register Name: USBCMD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |      |         |     |                                       |     |                         |     |                                                           |     |          |
|----------------|-----------------------------------------------------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|-----|---------------------------------------|-----|-------------------------|-----|-----------------------------------------------------------|-----|----------|
| Bit            | Read/Write                                                | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |      |         |     |                                       |     |                         |     |                                                           |     |          |
|                |                                                           |             | <p>field specifies the size of the Frame list. The size the frame list controls which bits in the Frame Index</p> <p>Register should be used for the Frame List Current index. Values mean:</p> <table border="1"> <thead> <tr> <th>Bits</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>00b</td><td>1024 elements(4096bytes)Default value</td></tr> <tr> <td>01b</td><td>512 elements(2048bytes)</td></tr> <tr> <td>10b</td><td>256 elements(1024bytes)For resource-constrained condition</td></tr> <tr> <td>11b</td><td>reserved</td></tr> </tbody> </table> <p>The default value is '00b'.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Bits | Meaning | 00b | 1024 elements(4096bytes)Default value | 01b | 512 elements(2048bytes) | 10b | 256 elements(1024bytes)For resource-constrained condition | 11b | reserved |
| Bits           | Meaning                                                   |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |         |     |                                       |     |                         |     |                                                           |     |          |
| 00b            | 1024 elements(4096bytes)Default value                     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |         |     |                                       |     |                         |     |                                                           |     |          |
| 01b            | 512 elements(2048bytes)                                   |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |         |     |                                       |     |                         |     |                                                           |     |          |
| 10b            | 256 elements(1024bytes)For resource-constrained condition |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |         |     |                                       |     |                         |     |                                                           |     |          |
| 11b            | reserved                                                  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |         |     |                                       |     |                         |     |                                                           |     |          |
| 1              | R/W                                                       | 0           | <p>Host Controller Reset</p> <p>This control bit is used by software to reset the host controller. The effects of this on Root Hub registers are similar to a Chip Hardware Reset.</p> <p>When software writes a one to this bit, the Host Controller resets its internal pipelines, timers, counters, state machines, etc. to their initial value. Any transaction currently in progress on USB is immediately terminated. A USB reset is not driven on downstream ports.</p> <p>All operational registers, including port registers and port state machines are set to their initial values. Port ownership reverts to the companion host controller(s). Software must reinitialize the host controller as described in Section 4.1 of the CHEI Specification in order to return the host controller to an operational state.</p> <p>This bit is set to zero by the Host Controller when the reset process is complete. Software cannot terminate the reset process early by writing a zero to this register.</p> <p>Software should not set this bit to a one when the HC Halted bit in the USBSTS register is a zero. Attempting to reset an actively running host controller will result in undefined behavior.</p> |      |         |     |                                       |     |                         |     |                                                           |     |          |
| 0              | R/W                                                       | 0           | <p>Run/Stop</p> <p>When set to a 1, the Host Controller proceeds with execution of the schedule. When set to 0, the Host Controller completes the current and any actively</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |      |         |     |                                       |     |                         |     |                                                           |     |          |

| Offset: 0x0010 |            |             | Register Name: USBCMD                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                |            |             | <p>pipelined transactions on the USB and then halts.</p> <p>The Host Controller must halt within 16 micro-frames after software clears this bit.</p> <p>The HC Halted bit indicates when the Host Controller has finished its pending pipelined transactions and has entered the stopped state.</p> <p>Software must not write a one to this field unless the Host Controller is in the Halt State.</p> <p>The default value is 0x0.</p> |

#### 8.8.6.7 0x0014 EHCI USB Status Register (Default Value:0x0000\_1000)

| Offset: 0x0014 |            |             | Register Name: E_USBSTS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 31:16          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 15             | R          | 0           | <p>Asynchronous Schedule Status</p> <p>The bit reports the current real status of Asynchronous Schedule. If this bit is a zero, then the status of the Asynchronous Schedule is disabled. If this bit is a one, then the status of the Asynchronous Schedule is enabled. The Host Controller is not required to immediately disable or enable the Asynchronous Schedule when software transitions the Asynchronous Schedule Enable bit in the USBCMD register. When this bit and the Asynchronous Schedule Enable bit are the same value, the Asynchronous Schedule is either enabled (1) or disabled (0).</p> |
| 14             | R          | 0           | <p>Periodic Schedule Status</p> <p>The bit reports the current real status of the Periodic Schedule. If this bit is a zero, then the status of the Periodic Schedule is disabled. If this bit is a one, then the status of the Periodic Schedule is enabled. The Host Controller is not required to <i>immediately</i> disable or enable the Periodic Schedule when software transitions the <i>Periodic Schedule Enable</i> bit in the USBCMD register. When this bit and the <i>Periodic Schedule Enable</i> bit are the same value, the Periodic Schedule is either enabled (1) or disabled (0).</p>        |
| 13             | R          | 0           | Reclamation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

| Offset: 0x0014 |            |             | Register Name: E_USBSTS                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                |            |             | This is a read-only status bit, which is used to detect an empty asynchronous schedule.                                                                                                                                                                                                                                                                                                                                                                     |
| 12             | R          | 1           | <p>HC Halted</p> <p>This bit is a zero whenever the Run/Stop bit is a one. The Host Controller Sets this bit to one after it has stopped executing as a result of the Run/Stop bit being set to 0, either by software or by the Host Controller Hardware (e.g. internal error).</p> <p>The default value is '1'.</p>                                                                                                                                        |
| 11:6           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 5              | R/WC       | 0           | <p>Interrupt on Async Advance</p> <p>System software can force the host controller to issue an interrupt the next time the host controller advances the asynchronous schedule by writing a one to the Interrupt on Async Advance Doorbell bit in the USBCMD register. This status bit indicates the assertion of that interrupt source.</p>                                                                                                                 |
| 4              | R/WC       | 0           | <p>Host System Error</p> <p>The Host Controller set this bit to 1 when a serious error occurs during a host system access involving the Host Controller module. When this error occurs, the Host Controller clears the Run/Stop bit in the Command register to prevent further execution of the scheduled TDs.</p>                                                                                                                                          |
| 3              | R/WC       | 0           | <p>Frame List Rollover</p> <p>The Host Controller sets this bit to a one when the Frame List Index rolls over from its maximum value to zero. The exact value at which the rollover occurs depends on the frame list size. For example, if the frame list size is 1024, the Frame Index Register rolls over every time FRINDEX [13] toggles. Similarly, if the size is 512, the Host Controller sets this bit to a one every time FRINDEX [12] toggles.</p> |
| 2              | R/WC       | 0           | <p>Port Change Detect</p> <p>The Host Controller sets this bit to a one when any port for which the Port Owner bit is set to zero has a change bit transition from a zero to a one or a Force Port Resume bit transition from a zero to a one as a result of a J-K transition detected on a suspended port. This bit will also be set as a result of the Connect Status Chang being set to a one after</p>                                                  |

| Offset: 0x0014 |            |             | Register Name: E_USBSTS                                                                                                                                                                                                                                                                                                                                    |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                |
|                |            |             | system software has relinquished ownership of a connected port by writing a one to a port's Port Owner bit.                                                                                                                                                                                                                                                |
| 1              | R/WC       | 0           | USB Error Interrupt(USBERRINT)<br>The Host Controller sets this bit to 1 when completion of USB transaction results in an error condition (e.g. error counter underflow). If the TD on which the error interrupt occurred also had its IOC bit set, both.<br>This bit and USBINT bit are set.                                                              |
| 0              | R/WC       | 0           | USB Interrupt(USBINT)<br>The Host Controller sets this bit to a one on the completion of a USB transaction, which results in the retirement of a Transfer Descriptor that had its IOC bit set.<br>The Host Controller also sets this bit to 1 when a short packet is detected (actual number of bytes received was less than the expected number of bytes) |

#### 8.8.6.8 0x0018 EHCI USB Interrupt Enable Register (Default Value:0x0000\_0000)

| Offset: 0x0018 |            |             | Register Name: E_USBINTR                                                                                                                                                                                                                                                                         |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                      |
| 31:6           | /          | /           | /                                                                                                                                                                                                                                                                                                |
| 5              | R/W        | 0           | Interrupt on Async Advance Enable<br>When this bit is 1, and the Interrupt on Async Advance bit in the USBSTS register is 1, the host controller will issue an interrupt at the next interrupt threshold. The interrupt is acknowledged by software clearing the Interrupt on Async Advance bit. |
| 4              | R/W        | 0           | Host System Error Enable<br>When this bit is 1, and the Host System Error Status bit in the USBSTS register is 1, the host controller will issue an interrupt. The interrupt is acknowledged by software clearing the Host System Error bit.                                                     |
| 3              | R/W        | 0           | Frame List Rollover Enable<br>When this bit is 1, and the Frame List Rollover bit in the USBSTS register is 1, the host controller will                                                                                                                                                          |

| Offset: 0x0018 |            |             | Register Name: E_USBINTR                                                                                                                                                                                                                                   |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                |
|                |            |             | issue an interrupt. The interrupt is acknowledged by software clearing the Frame List Rollover bit.                                                                                                                                                        |
| 2              | R/W        | 0           | Port Change Interrupt Enable<br>When this bit is 1, and the Port Chang Detect bit in the USBSTS register is 1, the host controller will issue an interrupt. The interrupt is acknowledged by software clearing the Port Chang Detect bit.                  |
| 1              | R/W        | 0           | USB Error Interrupt Enable<br>When this bit is 1, and the USBERRINT bit in the USBSTS register is 1, the host controller will issue an interrupt at the next interrupt threshold.<br>The interrupt is acknowledged by software clearing the USBERRINT bit. |
| 0              | R/W        | 0           | USB Interrupt Enable<br>When this bit is 1, and the USBINT bit in the USBSTS register is 1, the host controller will issue an interrupt at the next interrupt threshold.<br>The interrupt is acknowledged by software clearing the USBINT bit              |

#### 8.8.6.9 0x001C EHCI Frame Index Register (Default Value:0x0000\_0000)



##### NOTE

This register must be written as a DWord. Byte writes produce undefined results.

| Offset: 0x001C |            |             | Register Name: E_FRINDEX                                                                                                                                                                                                                                                                                                                                                                             |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                          |
| 31:14          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                    |
| 13:0           | R/W        | 0           | Frame Index<br>The value in this register increment at the end of each time frame (e.g. micro-frame). Bits[N:3] are used for the Frame List current index. It Means that each location of the frame list is accessed 8 times (frames or Micro-frames) before moving to the next index. The following illustrates Values of N based on the value of the Frame List Size field in the USBCMD register. |

| Offset: 0x001C |            |             | Register Name: E_FRINDEX |                 |    |  |
|----------------|------------|-------------|--------------------------|-----------------|----|--|
| Bit            | Read/Write | Default/Hex | Description              |                 |    |  |
|                |            |             | USBCMD[Frame List Size]  | Number Elements | N  |  |
|                |            |             | 00b                      | 1024            | 12 |  |
|                |            |             | 01b                      | 512             | 11 |  |
|                |            |             | 10b                      | 256             | 10 |  |
|                |            |             | 11b                      | Reserved        |    |  |

#### 8.8.6.10 0x0024 EHCI Periodic Frame List Base Address Register (Default Value:0x0000\_0000)



##### NOTE

Writes must be Dword Writes.

| Offset: 0x0024 |            |             | Register Name: E_PERIODICLISTBASE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
| 31:12          | R/W        |             | Base Address<br>These bits correspond to memory address signals [31:12], respectively.<br>This register contains the beginning address of the Periodic Frame List in the system memory.<br>System software loads this register prior to starting the schedule execution by the Host Controller. The memory structure referenced by this physical memory pointer is assumed to be 4-K byte aligned.<br>The contents of this register are combined with the Frame Index Register (FRINDEX) to enable the Host Controller to step through the Periodic Frame List in sequence. |  |  |  |
| 11:0           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |

#### 8.8.6.11 0x0028 EHCI Current Asynchronous List Address Register (Default Value:0x0000\_0000)



##### NOTE

Writes must be Dword Writes.

| Offset: 0x0028 |            |             | Register Name: E_ASYNCLISTADDR |  |
|----------------|------------|-------------|--------------------------------|--|
| Bit            | Read/Write | Default/Hex | Description                    |  |
|                |            |             |                                |  |

| Offset: 0x0028 |            |             | Register Name: E_ASYNCLISTADDR                                                                                                                                                    |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                       |
| 31:5           | R/W        |             | Link Pointer (LP)<br>This field contains the address of the next asynchronous queue head to be executed.<br>These bits correspond to memory address signals [31:5], respectively. |
| 4:0            | /          | /           | /                                                                                                                                                                                 |

#### 8.8.6.12 0x0050 EHCI Configure Flag Register (Default Value:0x0000\_0000)



##### NOTE

This register is not use in the normal implementation.

| Offset: 0x0050 |                                                                                                            |             | Register Name: E_CONFIGFLAG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |       |         |   |                                                                                                            |   |                                                                             |
|----------------|------------------------------------------------------------------------------------------------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|------------------------------------------------------------------------------------------------------------|---|-----------------------------------------------------------------------------|
| Bit            | Read/Write                                                                                                 | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |       |         |   |                                                                                                            |   |                                                                             |
| 31:1           | /                                                                                                          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |                                                                                                            |   |                                                                             |
| 0              | R/W                                                                                                        | 0           | <p>Configure Flag(CF)<br/>Host software sets this bit as the last action in its process of configuring the Host Controller. This bit controls the default port-routing control logic as follow:</p> <table border="1"> <thead> <tr> <th>Value</th> <th>Meaning</th> </tr> </thead> <tbody> <tr> <td>0</td> <td>Port routing control logic default-routs each port to an implementation dependent classic host controller.</td> </tr> <tr> <td>1</td> <td>Port routing control logic default-routs all ports to this host controller.</td> </tr> </tbody> </table> <p>The default value of this field is '0'.</p> | Value | Meaning | 0 | Port routing control logic default-routs each port to an implementation dependent classic host controller. | 1 | Port routing control logic default-routs all ports to this host controller. |
| Value          | Meaning                                                                                                    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |                                                                                                            |   |                                                                             |
| 0              | Port routing control logic default-routs each port to an implementation dependent classic host controller. |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |                                                                                                            |   |                                                                             |
| 1              | Port routing control logic default-routs all ports to this host controller.                                |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |         |   |                                                                                                            |   |                                                                             |

#### 8.8.6.13 0x0054 EHCI Port Status and Control Register (Default Value:0x0000\_2000)



##### NOTE

This register is only reset by hardware or in response to a host controller reset.

| Offset: 0x0054 | Register Name: E_PORTSC |
|----------------|-------------------------|
|----------------|-------------------------|

| Bit         | Read/Write                                | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
|-------------|-------------------------------------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|-------|-------------------------------------------|-------|--------------|-------|--------------|-------|--------------|-------|-------------|-------|-------------------|-------------|----------|
| 31:22       | /                                         | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
| 21          | R/W                                       | 0           | <p>Wake on Disconnect Enable(WKDSNNNT_E)<br/>                     Writing this bit to a one enables the port to be sensitive to device disconnects as wake-up events.<br/>                     This field is zero if Port Power is zero.<br/>                     The default value in this field is '0'.</p>                                                                                                                                                                                                                                                                                                                                                                                    |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
| 20          | R/W                                       | 0           | <p>Wake on Connect Enable(WKCNNT_E)<br/>                     Writing this bit to a one enable the port to be sensitive to device connects as wake-up events.<br/>                     This field is zero if Port Power is zero.<br/>                     The default value in this field is '0'.</p>                                                                                                                                                                                                                                                                                                                                                                                             |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
| 19:16       | R/W                                       | 0           | <p>Port Test Control<br/>                     The value in this field specifies the test mode of the port. The encoding of the test mode bits are as follow:</p> <table border="1"> <thead> <tr> <th>Bits</th><th>Test Mode</th></tr> </thead> <tbody> <tr> <td>0000b</td><td>The port is NOT operating in a test mode.</td></tr> <tr> <td>0001b</td><td>Test J_STATE</td></tr> <tr> <td>0010b</td><td>Test K_STATE</td></tr> <tr> <td>0011b</td><td>Test SEO_NAK</td></tr> <tr> <td>0100b</td><td>Test Packet</td></tr> <tr> <td>0101b</td><td>Test FORCE_ENABLE</td></tr> <tr> <td>0110b-1111b</td><td>Reserved</td></tr> </tbody> </table> <p>The default value in this field is '0000b'.</p> | Bits | Test Mode | 0000b | The port is NOT operating in a test mode. | 0001b | Test J_STATE | 0010b | Test K_STATE | 0011b | Test SEO_NAK | 0100b | Test Packet | 0101b | Test FORCE_ENABLE | 0110b-1111b | Reserved |
| Bits        | Test Mode                                 |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
| 0000b       | The port is NOT operating in a test mode. |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
| 0001b       | Test J_STATE                              |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
| 0010b       | Test K_STATE                              |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
| 0011b       | Test SEO_NAK                              |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
| 0100b       | Test Packet                               |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
| 0101b       | Test FORCE_ENABLE                         |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
| 0110b-1111b | Reserved                                  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
| 15:14       | /                                         | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
| 13          | R/W                                       | 1           | <p>Port Owner<br/>                     This bit unconditionally goes to a 0b when the Configured bit in the CONFIGFLAG register makes a 0b to 1b transition. This bit unconditionally goes to 1b whenever the Configured bit is zero.<br/>                     System software uses this field to release ownership of the port to selected host controller (in the event that the attached device is not a high-speed device). Software writes a one to this bit when the attached device is not a high-speed device. A one in this bit means that a companion host controller owns and controls the port.<br/>                     Default Value = 1b.</p>                                     |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
| 12          | /                                         | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |
| 11:10       | R                                         | 0           | Line Status                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |      |           |       |                                           |       |              |       |              |       |              |       |             |       |                   |             |          |

| Offset: 0x0054 |            |                                              | Register Name: E_PORTSC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |            |           |                |     |     |                                           |     |         |                                           |     |         |                                              |     |           |                                           |
|----------------|------------|----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-----------|----------------|-----|-----|-------------------------------------------|-----|---------|-------------------------------------------|-----|---------|----------------------------------------------|-----|-----------|-------------------------------------------|
| Bit            | Read/Write | Default/Hex                                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |            |           |                |     |     |                                           |     |         |                                           |     |         |                                              |     |           |                                           |
|                | /          | /                                            | <p>These bits reflect the current logical levels of the D+ (bit11) and D-(bit10) signal lines. These bits are used for detection of low-speed USB devices prior to port reset and enable sequence. This read only field is valid only when the port enable bit is zero and the current connect status bit is set to a one.</p> <p>The encoding of the bits are:</p> <table border="1"> <thead> <tr> <th>Bit[11:10]</th><th>USB State</th><th>Interpretation</th></tr> </thead> <tbody> <tr> <td>00b</td><td>SE0</td><td>Not Low-speed device, perform EHCI reset.</td></tr> <tr> <td>10b</td><td>J-state</td><td>Not Low-speed device, perform EHCI reset.</td></tr> <tr> <td>01b</td><td>K-state</td><td>Low-speed device, release ownership of port.</td></tr> <tr> <td>11b</td><td>Undefined</td><td>Not Low-speed device, perform EHCI reset.</td></tr> </tbody> </table> <p>This value of this field is undefined if Port Power is zero.</p>                                                                       | Bit[11:10] | USB State | Interpretation | 00b | SE0 | Not Low-speed device, perform EHCI reset. | 10b | J-state | Not Low-speed device, perform EHCI reset. | 01b | K-state | Low-speed device, release ownership of port. | 11b | Undefined | Not Low-speed device, perform EHCI reset. |
| Bit[11:10]     | USB State  | Interpretation                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |            |           |                |     |     |                                           |     |         |                                           |     |         |                                              |     |           |                                           |
| 00b            | SE0        | Not Low-speed device, perform EHCI reset.    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |            |           |                |     |     |                                           |     |         |                                           |     |         |                                              |     |           |                                           |
| 10b            | J-state    | Not Low-speed device, perform EHCI reset.    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |            |           |                |     |     |                                           |     |         |                                           |     |         |                                              |     |           |                                           |
| 01b            | K-state    | Low-speed device, release ownership of port. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |            |           |                |     |     |                                           |     |         |                                           |     |         |                                              |     |           |                                           |
| 11b            | Undefined  | Not Low-speed device, perform EHCI reset.    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |            |           |                |     |     |                                           |     |         |                                           |     |         |                                              |     |           |                                           |
| 9              | /          | /                                            | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |            |           |                |     |     |                                           |     |         |                                           |     |         |                                              |     |           |                                           |
| 8              | R/W        | 0                                            | <p>Port Reset</p> <p>1=Port is in Reset. 0=Port is not in Reset. Default value = 0.</p> <p>When software writes a one to this bit (from a zero), the bus reset sequence as defined in the USB Specification Revision 2.0 is started. Software writes a zero to this bit to terminate the bus reset sequence. Software must keep this bit at a one long enough to ensure the reset sequence, as specified in the USB Specification Revision 2.0, completes. Notes: when software writes this bit to a one , it must also write a zero to the Port Enable bit.</p> <p>Note that when software writes a zero to this bit there may be a delay before the bit status changes to a zero. The bit status will not read as a zero until after the reset has completed. If the port is in high-speed mode after reset is complete, the host controller will automatically enable this port (e.g. set the Port Enable bit to a one). A host controller must terminate the reset and stabilize the state of the port within 2</p> |            |           |                |     |     |                                           |     |         |                                           |     |         |                                              |     |           |                                           |

| Offset: 0x0054              |            |             | Register Name: E_PORTSC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                             |            |    |         |    |        |    |         |
|-----------------------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|------------|----|---------|----|--------|----|---------|
| Bit                         | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                             |            |    |         |    |        |    |         |
| 7                           | R/W        | 0           | <p>milliseconds of software transitioning this bit from a one to a zero. For example: if the port detects that the attached device is high-speed during reset, then the host controller must have the port in the enabled state with 2ms of software writing this bit to a zero. The HC Halted bit in the USBSTS register should be a zero before software attempts to use this bit. The host controller may hold Port Reset asserted to a one when the HC Halted bit is a one.</p> <p>This field is zero if Port Power is zero.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                             |            |    |         |    |        |    |         |
| 6                           | R/W        | 0           | <p>Suspend</p> <p>Port Enabled Bit and Suspend bit of this register define the port states as follows:</p> <table border="1"> <thead> <tr> <th>Bits[Port Enables, Suspend]</th><th>Port State</th></tr> </thead> <tbody> <tr> <td>0x</td><td>Disable</td></tr> <tr> <td>10</td><td>Enable</td></tr> <tr> <td>11</td><td>Suspend</td></tr> </tbody> </table> <p>When in suspend state, downstream propagation of data is blocked on this port, except for port reset. The blocking occurs at the end of the current transaction, if a transaction was in progress when this bit was written to 1. In the suspend state, the port is sensitive to resume detection. Note that the bit status does not change until the port is suspend and that there may be a delay in suspending a port if there is a transaction currently in progress on the USB.</p> <p>A write of zero to this bit is ignored by the host controller. The host controller will unconditionally set this bit to a zero when:</p> <ul style="list-style-type: none"> <li>• Software sets the Force Port Resume bit to a zero(from a one).</li> <li>• Software sets the Port Reset bit to a one(from a zero).</li> </ul> <p>If host software sets this bit to a one when the port is not enabled(i.e. Port enabled bit is a zero), the results are undefined.</p> <p>This field is zero if Port Power is zero.</p> <p>The default value in this field is '0'.</p> | Bits[Port Enables, Suspend] | Port State | 0x | Disable | 10 | Enable | 11 | Suspend |
| Bits[Port Enables, Suspend] | Port State |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                             |            |    |         |    |        |    |         |
| 0x                          | Disable    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                             |            |    |         |    |        |    |         |
| 10                          | Enable     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                             |            |    |         |    |        |    |         |
| 11                          | Suspend    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                             |            |    |         |    |        |    |         |

| Offset: 0x0054 |            |             | Register Name: E_PORTSC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                |            |             | <p>(K-state) detected/ driven on port. Default value = 0. This functionality defined for manipulating this bit depends on the value of the Suspend bit. For example, if the port is not suspend and software transitions this bit to a one, then the effects on the bus are undefined.</p> <p>Software sets this bit to a 1 drive resume signaling. The Host Controller sets this bit to a 1 if a J-to-K transition is detected while the port is in the Suspend state. When this bit transitions to a one because a J-to-K transition is detected, the Port Change Detect bit in the USBSTS register is also set to a one. If software sets this bit to a one, the host controller must not set the Port Change Detect bit.</p> <p>Note that when the EHCI controller owns the port, the resume sequence follows the defined sequence documented in the USB Specification Revision 2.0. The resume signaling (Full-speed 'K') is driven on the port as long as this remains a one. Software must appropriately time the Resume and set this bit to a zero when the appropriate amount of time has elapsed. Writing a zero (from one) causes the port to return high-speed mode (forcing the bus below the port into a high-speed idle). This bit will remain a one until the port has switched to high-speed idle. The host controller must complete this transition within 2 milliseconds of software setting this bit to a zero. This field is zero if Port Power is zero.</p> |
| 5              | R/WC       | 0           | <p>Over-current Change<br/>Default = 0. This bit gets set to a one when there is a change to Over-current Active. Software clears this bit by writing a one to this bit position.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 4              | R          | 0           | <p>Over-current Active<br/>0 = This port does not have an over-current condition. 1 = This port currently has an over-current condition. This bit will automatically transition from a one to a zero when the over current condition is removed.<br/>The default value of this bit is '0'.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 3              | R/WC       | 0           | <p>Port Enable/Disable Change<br/>Default = 0. 1 = Port enabled/disabled status has</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

| Offset: 0x0054 |            |             | Register Name: E_PORTSC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                |            |             | <p>changed. 0 = No change.</p> <p>For the root hub, this bit gets set to a one only when a port is disabled due to the appropriate conditions existing at the EOF2 point (See Chapter 11 of the USB Specification for the definition of a Port Error).</p> <p>Software clears this bit by writing a 1 to it.</p> <p>This field is zero if Port Power is zero.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 2              | R/W        | 0           | <p>Port Enabled/Disabled</p> <p>1=Enable, 0=Disable. Ports can only be enabled by the host controller as a part of the reset and enable. Software cannot enable a port by writing a one to this field. The host controller will only set this bit to a one when the reset sequence determines that the attached device is a high-speed device.</p> <p>Ports can be disabled by either a fault condition (Disconnect event or other fault condition) or by host software. Note that the bit status does not change until the port state actually changes. There may be a delay in disabling or enabling a port due to other host controller and bus events.</p> <p>When the port is disabled, downstream propagation of data is blocked on this port except for reset.</p> <p>The default value of this field is '0'.</p> <p>This field is zero if Port Power is zero.</p> |
| 1              | R/WC       | 0           | <p>Connect Status Change</p> <p>1=Change in Current Connect Status, 0=No change, Default=0.</p> <p>Indicates a change has occurred in the port's Current Connect Status. The host controller sets this bit for all changes to the port device connect status, even if system software has not cleared an existing connect status change. For example, the insertion status changes twice before system software has cleared the changed condition, hub hardware will be "setting" an already-set bit. Software sets this bit to 0 by writing a 1 to it.</p> <p>This field is zero if Port Power is zero.</p>                                                                                                                                                                                                                                                              |
| 0              | R          | 0           | <p>Current Connect Status</p> <p>Device is present on port when the value of this field is a one, and no device is present on port when the value of this field is a zero. This value reflects the</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

| Offset: 0x0054 |            |             | Register Name: E_PORTSC                                                                                                                                                   |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                               |
|                |            |             | current state of the port, and may not correspond directly to the event that caused the Connect Status Change(Bit 1) to be set.<br>This field is zero if Port Power zero. |

### 8.8.7 OHCI Register Description

#### 8.8.7.1 0x0400 OHCI Revision Register (Default Value:0x10)

| Offset: 0x0400 |            |    |             | Register Name: O_HcRevision                                                                                                                                                                                                                                                                           |
|----------------|------------|----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                                                                                                                                                                                                                                                                                           |
|                | HCD        | HC |             |                                                                                                                                                                                                                                                                                                       |
| 31:8           | /          | /  | /           | /                                                                                                                                                                                                                                                                                                     |
| 7:0            | R          | R  | 0x10        | Revision<br>This read-only field contains the BCD representation of the version of the HCI specification that is implemented by this HC. For example, a value of 0x11 corresponds to version 1.1. All of the HC implementations that are compliant with this specification will have a value of 0x10. |

#### 8.8.7.2 0x0404 OHCI Control Register (Default Value:0x0000\_0000)

| Offset: 0x0404 |            |     |             | Register Name: O_HcControl                                                                                                                                                                                                                                                                                                                         |
|----------------|------------|-----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                        |
|                | HCD        | HC  |             |                                                                                                                                                                                                                                                                                                                                                    |
| 31:11          | /          | /   | /           | /                                                                                                                                                                                                                                                                                                                                                  |
| 10             | R/W        | R   | 0x0         | RemoteWakeupEnable<br>This bit is used by HCD to enable or disable the remote wakeup feature upon the detection of upstream resume signaling. When this bit is set and the ResumeDetected bit in HcInterruptStatus is set, a remote wakeup is signaled to the host system. Setting this bit has no impact on the generation of hardware interrupt. |
| 9              | R/W        | R/W | 0x0         | RemoteWakeupConnected<br>This bit indicates whether HC supports remote wakeup signaling. If remote wakeup is supported                                                                                                                                                                                                                             |

| Offset: 0x0404 |                |     |             | Register Name: O_HcControl                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |     |          |     |           |     |                |     |            |
|----------------|----------------|-----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|----------|-----|-----------|-----|----------------|-----|------------|
| Bit            | Read/Write     |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |     |          |     |           |     |                |     |            |
|                | HCD            | HC  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |          |     |           |     |                |     |            |
|                |                |     |             | and used by the system, it is the responsibility of system firmware to set this bit during POST. HC clear the bit upon a hardware reset but does not alter it upon a software reset. Remote wakeup signaling of the host system is host-bus-specific and is not described in this specification.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |     |          |     |           |     |                |     |            |
| 8              | R/W            | R   | 0x0         | <p>InterruptRouting</p> <p>This bit determines the routing of interrupts generated by events registered in HcInterruptStatus. If clear, all interrupt is routed to the normal host bus interrupt mechanism. If set interrupts are routed to the System Management Interrupt. HCD clears this bit upon a hardware reset, but it does not alter this bit upon a software reset. HCD uses this bit as a tag to indicate the ownership of HC.</p>                                                                                                                                                                                                                                                                                                                                                                                                                          |     |          |     |           |     |                |     |            |
| 7:6            | R/W            | R/W | 0x0         | <p>HostControllerFunctionalState for USB</p> <table border="1"> <tr><td>00b</td><td>USBReset</td></tr> <tr><td>01b</td><td>USBResume</td></tr> <tr><td>10b</td><td>USBOperational</td></tr> <tr><td>11b</td><td>USBSuspend</td></tr> </table> <p>A transition to USBOperational from another state causes SOF generation to begin 1 ms later. HCD may determine whether HC has begun sending SOFs by reading the StartFrame field of HcInterruptStatus.</p> <p>This field may be changed by HC only when in the USBSUSPEND state. HC may move from the USBSUSPEND state to the USBRESUME state after detecting the resume signaling from a downstream port.</p> <p>HC enters USBSUSPEND after a software reset, whereas it enters USBRESET after a hardware reset. The latter also resets the Root Hub and asserts subsequent reset signaling to downstream ports.</p> | 00b | USBReset | 01b | USBResume | 10b | USBOperational | 11b | USBSuspend |
| 00b            | USBReset       |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |          |     |           |     |                |     |            |
| 01b            | USBResume      |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |          |     |           |     |                |     |            |
| 10b            | USBOperational |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |          |     |           |     |                |     |            |
| 11b            | USBSuspend     |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |     |          |     |           |     |                |     |            |
| 5              | R/W            | R   | 0x0         | <p>BulkListEnable</p> <p>This bit is set to enable the processing of the Bulk list in the next</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |          |     |           |     |                |     |            |

| Offset: 0x0404 |            |    |             | Register Name: O_HcControl                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                | HCD        | HC |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                |            |    |             | Frame. If cleared by HCD, processing of the Bulk list does not occur after the next SOF. HC checks this bit whenever it determines to process the list. When disabled, HCD may modify the list. If HcBulkCurrentED is pointing to an ED to be removed, HCD must advance the pointer by updating HcBulkCurrentED before re-enabling processing of the list.                                                                                                                                                                  |
| 4              | R/W        | R  | 0x0         | ControlListEnable<br>This bit is set to enable the processing of the Control list in the next Frame. If cleared by HCD, processing of the Control list does not occur after the next SOF. HC must check this bit whenever it determines to process the list. When disabled, HCD may modify the list. If HcControlCurrentED is pointing to an ED to be removed, HCD must advance the pointer by updating HcControlCurrentED before re-enabling processing of the list.                                                       |
| 3              | R/W        | R  | 0x0         | IsochronousEnable<br>This bit is used by HCD to enable/disable processing of isochronous EDs. While processing the periodic list in a Frame, HC checks the status of this bit when it finds an Isochronous ED (F=1). If set (enabled), HC continues processing the EDs. If cleared (disabled), HC halts processing of the periodic list (which now contains only isochronous EDs) and begins processing the Bulk/Control lists.<br>Setting this bit is guaranteed to take effect in the next Frame (not the current Frame). |
| 2              | R/W        | R  | 0x0         | PeriodicListEnable<br>This bit is set to enable the processing of periodic list in the next Frame. If cleared by HCD, processing of the periodic list does not occur after the next SOF. HC must check this bit before it starts processing the list.                                                                                                                                                                                                                                                                       |
| 1:0            | R/W        | R  | 0x0         | ControlBulkServiceRatio<br>This specifies the service ratio between Control and Bulk EDs. Before processing any of the                                                                                                                                                                                                                                                                                                                                                                                                      |

| Offset: 0x0404 |                                         |    |             | Register Name: O_HcControl                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |      |                                         |   |     |   |     |   |     |   |     |
|----------------|-----------------------------------------|----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------------------------------------|---|-----|---|-----|---|-----|---|-----|
| Bit            | Read/Write                              |    | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |      |                                         |   |     |   |     |   |     |   |     |
|                | HCD                                     | HC |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |                                         |   |     |   |     |   |     |   |     |
|                |                                         |    |             | <p>nonperiodic lists, HC must compare the ratio specified with its internal count on how many nonempty Control EDs have been processed, in determining whether to continue serving another Control ED or switching to Bulk EDs. The internal count will be retained when crossing the frame boundary. In case of reset, HCD is responsible for restoring this value.</p> <table border="1"> <tr> <td>CBSR</td> <td>No. of Control EDs Over Bulk EDs Served</td> </tr> <tr> <td>0</td> <td>1:1</td> </tr> <tr> <td>1</td> <td>2:1</td> </tr> <tr> <td>2</td> <td>3:1</td> </tr> <tr> <td>3</td> <td>4:1</td> </tr> </table> <p>The default value is 0x0.</p> | CBSR | No. of Control EDs Over Bulk EDs Served | 0 | 1:1 | 1 | 2:1 | 2 | 3:1 | 3 | 4:1 |
| CBSR           | No. of Control EDs Over Bulk EDs Served |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |                                         |   |     |   |     |   |     |   |     |
| 0              | 1:1                                     |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |                                         |   |     |   |     |   |     |   |     |
| 1              | 2:1                                     |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |                                         |   |     |   |     |   |     |   |     |
| 2              | 3:1                                     |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |                                         |   |     |   |     |   |     |   |     |
| 3              | 4:1                                     |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |                                         |   |     |   |     |   |     |   |     |

#### 8.8.7.3 0x0408 OHCI Command Status Register (Default Value:0x0000\_0000)

| Offset: 0x0408 |            |     |             | Register Name: O_HcCommandStatus                                                                                                                                                                                                                                                                                                                          |
|----------------|------------|-----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                               |
|                | HCD        | HC  |             |                                                                                                                                                                                                                                                                                                                                                           |
| 31:18          | /          | /   | 0x0         | Reserved                                                                                                                                                                                                                                                                                                                                                  |
| 17:16          | R          | R/W | 0x0         | <p>SchedulingOverrunCount</p> <p>These bits are incremented on each scheduling overrun error. It is initialized to 00b and wraps around at 11b. This will be incremented when a scheduling overrun is detected even if SchedulingOverrun in HcInterruptStatus has already been set. This is used by HCD to monitor any persistent scheduling problem.</p> |
| 15:4           | /          | /   | /           | /                                                                                                                                                                                                                                                                                                                                                         |
| 3              | R/W        | R/W | 0x0         | <p>OwnershipChangeRequest</p> <p>This bit is set by an OS HCD to request a change of control of the HC. When set HC will set the OwnershipChange field in HcInterruptStatus. After the changeover, this bit is cleared and remains so until the next request from OS HCD.</p>                                                                             |
| 2              | R/W        | R/W | 0x0         | <p>BulkListFilled</p> <p>This bit is used to indicate whether there are any TDs on the Bulk list. It is set by HCD whenever it adds a TD to an ED in the Bulk list.</p>                                                                                                                                                                                   |

| Offset: 0x0408 |            |     |             | Register Name: O_HcCommandStatus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------|------------|-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                | HCD        | HC  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                |            |     |             | When HC begins to process the head of the Bulk list, it checks BLF. As long as BulkListFilled is 0, HC will not start processing the Bulk list. If BulkListFilled is 1, HC will start processing the Bulk list and will set BF to 0. If HC finds a TD on the list, then HC will set BulkListFilled to 1 causing the Bulk list processing to continue. If no TD is found on the Bulk list, and if HCD does not set BulkListFilled, then BulkListFilled will still be 0 when HC completes processing the Bulk list and Bulk list processing will stop.                                                                                                                                                                                                                                 |
| 1              | R/W        | R/W | 0x0         | <p>ControlListFilled</p> <p>This bit is used to indicate whether there are any TDs on the Control list. It is set by HCD whenever it adds a TD to an ED in the Control list.</p> <p>When HC begins to process the head of the Control list, it checks CLF. As long as ControlListFilled is 0, HC will not start processing the Control list. If CF is 1, HC will start processing the Control list and will set ControlListFilled to 0. If HC finds a TD on the list, then HC will set ControlListFilled to 1 causing the Control list processing to continue. If no TD is found on the Control list, and if the HCD does not set ControlListFilled, then ControlListFilled will still be 0 when HC completes processing the Control list and Control list processing will stop.</p> |
| 0              | R/W        | R/E | 0x0         | <p>HostControllerReset</p> <p>This bit is by HCD to initiate a software reset of HC. Regardless of the functional state of HC, it moves to the USBsuspend state in which most of the operational registers are reset except those stated otherwise; e.g., the InterruptRouting field of HcControl, and no Host bus accesses are allowed. This bit is cleared by HC upon the completion of the reset operation. The reset operation must be completed within 10 ms. This bit, when set, should not cause a reset to the Root Hub and no subsequent reset signaling should be asserted to its downstream ports.</p>                                                                                                                                                                    |

#### 8.8.7.4 0x040C OHCI Interrupt Status Register (Default Value:0x0000\_0000)

|                |                                    |
|----------------|------------------------------------|
| Offset: 0x040C | Register Name: O_HcInterruptStatus |
|----------------|------------------------------------|

| Bit  | Read/Write |     | Default/Hex | Description                                                                                                                                                                                                                                                                  |
|------|------------|-----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | HCD        | HC  |             |                                                                                                                                                                                                                                                                              |
| 31:7 | /          | /   | /           | /                                                                                                                                                                                                                                                                            |
| 6    | R/W        | R/W | 0x0         | <p>RootHubStatusChange<br/>This bit is set when the content of HcRhStatus or the content of any of HcRhPortStatus[NumberofDownstreamPort] has changed.</p>                                                                                                                   |
| 5    | R/W        | R/W | 0x0         | <p>FrameNumberOverflow<br/>This bit is set when the MSb of HcFmNumber (bit 15) changes value, from 0 to 1 or from 1 to 0, and after HccaFrameNumber has been updated.</p>                                                                                                    |
| 4    | R/W        | R/W | 0x0         | <p>UnrecoverableError<br/>This bit is set when HC detects a system error not related to USB. HC should not proceed with any processing nor signaling before the system error has been corrected. HCD clears this bit after HC has been reset.</p>                            |
| 3    | R/W        | R/W | 0x0         | <p>ResumeDetected<br/>This bit is set when HC detects that a device on the USB is asserting resume signaling. It is the transition from no resume signaling to resume signaling causing this bit to be set. This bit is not set when HCD sets the USBRseume state.</p>       |
| 2    | R/W        | R/W | 0x0         | <p>StartofFrame<br/>This bit is set by HC at each start of frame and after the update of HccaFrameNumber. HC also generates a SOF token at the same time.</p>                                                                                                                |
| 1    | R/W        | R/W | 0x0         | <p>WritebackDoneHead<br/>This bit is set immediately after HC has written HcDoneHead to HccaDoneHead. Further updates of the HccaDoneHead will not occur until this bit has been cleared. HCD should only clear this bit after it has saved the content of HccaDoneHead.</p> |
| 0    | R/W        | R/W | 0x0         | <p>SchedulingOverrun<br/>This bit is set when the USB schedule for the current Frame overruns and after the update of HccaFrameNumber. A scheduling overrun will also cause the SchedulingOverrunCount of HcCommandStatus to be Incremented.</p>                             |

## 8.8.7.5 0x0410 OHCI Interrupt Enable Register (Default Value:0x0000\_0000)

| Offset: 0x0410 |                                                           |    |             | Register Name: O_HcInterruptEnable                                                                                                                                                                                                                     |   |         |   |                                                           |
|----------------|-----------------------------------------------------------|----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------|---|-----------------------------------------------------------|
| Bit            | Read/Write                                                |    | Default/Hex | Description                                                                                                                                                                                                                                            |   |         |   |                                                           |
|                | HCD                                                       | HC |             |                                                                                                                                                                                                                                                        |   |         |   |                                                           |
| 31             | R/W                                                       | R  | 0x0         | <p>MasterInterruptEnable</p> <p>A '0' written to this field is ignored by HC. A '1' written to this field enables interrupt generation due to events specified in the other bits of this register. This is used by HCD as Master Interrupt Enable.</p> |   |         |   |                                                           |
| 30:7           | /                                                         | /  | /           | /                                                                                                                                                                                                                                                      |   |         |   |                                                           |
| 6              | R/W                                                       | R  | 0x0         | <p>RootHubStatusChange Interrupt Enable</p> <table border="1"> <tr> <td>0</td><td>Ignore</td></tr> <tr> <td>1</td><td>Enable interrupt generation due to Root Hub Status Change</td></tr> </table>                                                     | 0 | Ignore  | 1 | Enable interrupt generation due to Root Hub Status Change |
| 0              | Ignore                                                    |    |             |                                                                                                                                                                                                                                                        |   |         |   |                                                           |
| 1              | Enable interrupt generation due to Root Hub Status Change |    |             |                                                                                                                                                                                                                                                        |   |         |   |                                                           |
| 5              | R/W                                                       | R  | 0x0         | <p>FrameNumberOverflow Interrupt Enable</p> <table border="1"> <tr> <td>0</td><td>Ignore;</td></tr> <tr> <td>1</td><td>Enable interrupt generation due to Frame Number Over Flow</td></tr> </table>                                                    | 0 | Ignore; | 1 | Enable interrupt generation due to Frame Number Over Flow |
| 0              | Ignore;                                                   |    |             |                                                                                                                                                                                                                                                        |   |         |   |                                                           |
| 1              | Enable interrupt generation due to Frame Number Over Flow |    |             |                                                                                                                                                                                                                                                        |   |         |   |                                                           |
| 4              | R/W                                                       | R  | 0x0         | <p>UnrecoverableError Interrupt Enable</p> <table border="1"> <tr> <td>0</td><td>Ignore</td></tr> <tr> <td>1</td><td>Enable interrupt generation due to Unrecoverable Error</td></tr> </table>                                                         | 0 | Ignore  | 1 | Enable interrupt generation due to Unrecoverable Error    |
| 0              | Ignore                                                    |    |             |                                                                                                                                                                                                                                                        |   |         |   |                                                           |
| 1              | Enable interrupt generation due to Unrecoverable Error    |    |             |                                                                                                                                                                                                                                                        |   |         |   |                                                           |
| 3              | R/W                                                       | R  | 0x0         | <p>ResumeDetected Interrupt Enable</p> <table border="1"> <tr> <td>0</td><td>Ignore</td></tr> <tr> <td>1</td><td>Enable interrupt generation due to Resume Detected</td></tr> </table>                                                                 | 0 | Ignore  | 1 | Enable interrupt generation due to Resume Detected        |
| 0              | Ignore                                                    |    |             |                                                                                                                                                                                                                                                        |   |         |   |                                                           |
| 1              | Enable interrupt generation due to Resume Detected        |    |             |                                                                                                                                                                                                                                                        |   |         |   |                                                           |
| 2              | R/W                                                       | R  | 0x0         | <p>StartofFrame Interrupt Enable</p> <table border="1"> <tr> <td>0</td><td>Ignore</td></tr> <tr> <td>1</td><td>Enable interrupt generation due to Start of Flame</td></tr> </table>                                                                    | 0 | Ignore  | 1 | Enable interrupt generation due to Start of Flame         |
| 0              | Ignore                                                    |    |             |                                                                                                                                                                                                                                                        |   |         |   |                                                           |
| 1              | Enable interrupt generation due to Start of Flame         |    |             |                                                                                                                                                                                                                                                        |   |         |   |                                                           |
| 1              | R/W                                                       | R  | 0x0         | <p>WritebackDoneHead Interrupt Enable</p> <table border="1"> <tr> <td>0</td><td>Ignore</td></tr> <tr> <td>1</td><td>Enable interrupt generation due to Write back Done Head</td></tr> </table>                                                         | 0 | Ignore  | 1 | Enable interrupt generation due to Write back Done Head   |
| 0              | Ignore                                                    |    |             |                                                                                                                                                                                                                                                        |   |         |   |                                                           |
| 1              | Enable interrupt generation due to Write back Done Head   |    |             |                                                                                                                                                                                                                                                        |   |         |   |                                                           |
| 0              | R/W                                                       | R  | 0x0         | <p>SchedulingOverrun Interrupt Enable</p> <table border="1"> <tr> <td>0</td><td>Ignore</td></tr> <tr> <td>1</td><td>Enable interrupt generation due to Scheduling Overrun</td></tr> </table>                                                           | 0 | Ignore  | 1 | Enable interrupt generation due to Scheduling Overrun     |
| 0              | Ignore                                                    |    |             |                                                                                                                                                                                                                                                        |   |         |   |                                                           |
| 1              | Enable interrupt generation due to Scheduling Overrun     |    |             |                                                                                                                                                                                                                                                        |   |         |   |                                                           |

## 8.8.7.6 0x0414 OHCI Interrupt Disable Register (Default Value:0x0000\_0000)

| Offset: 0x0414 |                                                            |    |         | Register Name: O_HcInterruptDisable                                                                                                                                                                                                                        |   |        |   |                                                            |
|----------------|------------------------------------------------------------|----|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|--------|---|------------------------------------------------------------|
| Bit            | Read/Write                                                 |    | Default | Description                                                                                                                                                                                                                                                |   |        |   |                                                            |
|                | HCD                                                        | HC |         |                                                                                                                                                                                                                                                            |   |        |   |                                                            |
| 31             | R/W                                                        | R  | 0x0     | <p>MasterInterruptEnable</p> <p>A written '0' to this field is ignored by HC. A '1' written to this field disables interrupt generation due events specified in the other bits of this register. This field is set after a hardware or software reset.</p> |   |        |   |                                                            |
| 30:7           | /                                                          | /  | /       | /                                                                                                                                                                                                                                                          |   |        |   |                                                            |
| 6              | R/W                                                        | R  | 0x0     | <p>RootHubStatusChange Interrupt Disable</p> <table border="1"> <tr> <td>0</td><td>Ignore</td></tr> <tr> <td>1</td><td>Disable interrupt generation due to Root Hub Status Change</td></tr> </table>                                                       | 0 | Ignore | 1 | Disable interrupt generation due to Root Hub Status Change |
| 0              | Ignore                                                     |    |         |                                                                                                                                                                                                                                                            |   |        |   |                                                            |
| 1              | Disable interrupt generation due to Root Hub Status Change |    |         |                                                                                                                                                                                                                                                            |   |        |   |                                                            |
| 5              | R/W                                                        | R  | 0x0     | <p>FrameNumberOverflow Interrupt Disable</p> <table border="1"> <tr> <td>0</td><td>Ignore</td></tr> <tr> <td>1</td><td>Disable interrupt generation due to Frame Number Over Flow</td></tr> </table>                                                       | 0 | Ignore | 1 | Disable interrupt generation due to Frame Number Over Flow |
| 0              | Ignore                                                     |    |         |                                                                                                                                                                                                                                                            |   |        |   |                                                            |
| 1              | Disable interrupt generation due to Frame Number Over Flow |    |         |                                                                                                                                                                                                                                                            |   |        |   |                                                            |
| 4              | R/W                                                        | R  | 0x0     | <p>UnrecoverableError Interrupt Disable</p> <table border="1"> <tr> <td>0</td><td>Ignore</td></tr> <tr> <td>1</td><td>Disable interrupt generation due to Unrecoverable Error</td></tr> </table>                                                           | 0 | Ignore | 1 | Disable interrupt generation due to Unrecoverable Error    |
| 0              | Ignore                                                     |    |         |                                                                                                                                                                                                                                                            |   |        |   |                                                            |
| 1              | Disable interrupt generation due to Unrecoverable Error    |    |         |                                                                                                                                                                                                                                                            |   |        |   |                                                            |
| 3              | R/W                                                        | R  | 0x0     | <p>ResumeDetected Interrupt Disable</p> <table border="1"> <tr> <td>0</td><td>Ignore</td></tr> <tr> <td>1</td><td>Disable interrupt generation due to Resume Detected</td></tr> </table>                                                                   | 0 | Ignore | 1 | Disable interrupt generation due to Resume Detected        |
| 0              | Ignore                                                     |    |         |                                                                                                                                                                                                                                                            |   |        |   |                                                            |
| 1              | Disable interrupt generation due to Resume Detected        |    |         |                                                                                                                                                                                                                                                            |   |        |   |                                                            |
| 2              | R/W                                                        | R  | 0x0     | <p>StartofFrame Interrupt Disable</p> <table border="1"> <tr> <td>0</td><td>Ignore</td></tr> <tr> <td>1</td><td>Disable interrupt generation due to Start of Flame</td></tr> </table>                                                                      | 0 | Ignore | 1 | Disable interrupt generation due to Start of Flame         |
| 0              | Ignore                                                     |    |         |                                                                                                                                                                                                                                                            |   |        |   |                                                            |
| 1              | Disable interrupt generation due to Start of Flame         |    |         |                                                                                                                                                                                                                                                            |   |        |   |                                                            |
| 1              | R/W                                                        | R  | 0x0     | <p>WritebackDoneHead Interrupt Disable</p> <table border="1"> <tr> <td>0</td><td>Ignore</td></tr> <tr> <td>1</td><td>Disable interrupt generation due to Write back Done Head</td></tr> </table>                                                           | 0 | Ignore | 1 | Disable interrupt generation due to Write back Done Head   |
| 0              | Ignore                                                     |    |         |                                                                                                                                                                                                                                                            |   |        |   |                                                            |
| 1              | Disable interrupt generation due to Write back Done Head   |    |         |                                                                                                                                                                                                                                                            |   |        |   |                                                            |
| 0              | R/w                                                        | R  | 0x0     | <p>SchedulingOverrun Interrupt Disable</p> <table border="1"> <tr> <td>0</td><td>Ignore</td></tr> <tr> <td>1</td><td>Disable interrupt generation due to Scheduling Overrun</td></tr> </table>                                                             | 0 | Ignore | 1 | Disable interrupt generation due to Scheduling Overrun     |
| 0              | Ignore                                                     |    |         |                                                                                                                                                                                                                                                            |   |        |   |                                                            |
| 1              | Disable interrupt generation due to Scheduling Overrun     |    |         |                                                                                                                                                                                                                                                            |   |        |   |                                                            |

#### 8.8.7.7 0x0418 OHCI HCCA Register (Default Value:0x0000\_0000)

| Offset: 0x0418 |            |    |             | Register Name: O_HcHCCA                                                                                                                                                                                                                   |
|----------------|------------|----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                                                                                                                                                                                                                               |
|                | HCD        | HC |             |                                                                                                                                                                                                                                           |
| 31:8           | R/W        | R  | 0x0         | HCCA [31:8]<br>This is the base address of the Host Controller Communication Area. This area is used to hold the control structures and the Interrupt table that are accessed by both the Host Controller and the Host Controller Driver. |
| 7:0            | R          | R  | 0x0         | HCCA [7:0]<br>The alignment restriction in HcHCCA register is evaluated by examining the number of zeros in the lower order bits. The minimum alignment is 256 bytes, therefore, bits 0 through 7 must always return 0 when read.         |

#### 8.8.7.8 0x041C OHCI Period Current ED Register (Default Value:0x0000\_0000)

| Offset: 0x041C |            |     |             | Register Name: O_HcPeriodCurrentED                                                                                                                                                                                                                                                                                           |
|----------------|------------|-----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                  |
|                | HCD        | HC  |             |                                                                                                                                                                                                                                                                                                                              |
| 31:4           | R          | R/W | 0x0         | PCED [31:4]<br>This is used by HC to point to the head of one of the Periodic list which will be processed in the current Frame. The content of this register is updated by HC after a periodic ED has been processed. HCD may read the content in determining which ED is currently being processed at the time of reading. |
| 3:0            | R          | R   | 0x0         | PCED [3:0]<br>Because the general TD length is 16 bytes, the memory structure for the TD must be aligned to a 16-byte boundary. So the lower bits in the PCED, through bit 0 to bit 3 must be zero in this field.                                                                                                            |

#### 8.8.7.9 0x0420 OHCI Control Head ED Register (Default Value:0x0000\_0000)

| Offset: 0x0420 |            |    |             | Register Name: O_HcControlHeadED |
|----------------|------------|----|-------------|----------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                      |
|                | HCD        | HC |             |                                  |
|                |            |    |             |                                  |

| Offset: 0x0420 |            |    |             | Register Name: O_HcControlHeadED                                                                                                                                                                                                                                                    |
|----------------|------------|----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                                                                                                                                                                                                                                                                         |
|                | HCD        | HC |             |                                                                                                                                                                                                                                                                                     |
| 31:4           | R/W        | R  | 0x0         | <p>EHCD [31:4]</p> <p>The HcControlHeadED register contains the physical address of the first Endpoint Descriptor of the Control list. HC traverse the Control list starting with the HcControlHeadED pointer. The content is loaded from HCCA during the initialization of HC.</p> |
| 3:0            | R          | R  | 0x0         | <p>EHCD [3:0]</p> <p>Because the general TD length is 16 bytes, the memory structure for the TD must be aligned to a 16-byte boundary. So the lower bits in the PCED, through bit 0 to bit 3 must be zero in this field.</p>                                                        |

#### 8.8.7.10 0x0424 OHCI Control Current ED Register (Default Value:0x0000\_0000)

| Offset: 0x0424 |            |     |             | Register Name: HcControlCurrentED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                | HCD        | HC  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 31:4           | R/W        | R/W | 0x0         | <p>CCED [31:4]</p> <p>The pointer is advanced to the next ED after serving the present one. HC will continue processing the list from where it left off in the last Frame. When it reaches the end of the Control list, HC checks the ControlListFilled of in HcCommandStatus. If set, it copies the content of HcControlHeadED to HcControlCurrentED and clears the bit. If not set, it does nothing.</p> <p>HCD is allowed to modify this register only when the ControlListEnable of HcControl is cleared. When set, HCD only reads the instantaneous value of this register. Initially, this is set to zero to indicate the end of the Control list.</p> |
| 3:0            | R          | R   | 0x0         | <p>CCED [3:0]</p> <p>Because the general TD length is 16 bytes, the memory structure for the TD must be aligned to a 16-byte boundary. So the lower bits in the PCED, through bit 0 to bit 3 must be zero in this field.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                 |

### 8.8.7.11 0x0428 OHCI Bulk Head ED Register (Default Value:0x0000\_0000)

| Offset: 0x0428 |            |    |             | Register Name: O_HcBulkHeadED                                                                                                                                                                                                                                 |
|----------------|------------|----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                                                                                                                                                                                                                                                   |
|                | HCD        | HC |             |                                                                                                                                                                                                                                                               |
| 31:4           | R/W        | R  | 0x0         | BHED [31:4]<br>The HcBulkHeadED register contains the physical address of the first Endpoint Descriptor of the Bulk list. HC traverses the Bulk list starting with the HcBulkHeadED pointer. The content is loaded from HCCA during the initialization of HC. |
| 3:0            | R          | R  | 0x0         | BHED [3:0]<br>Because the general TD length is 16 bytes, the memory structure for the TD must be aligned to a 16-byte boundary. So the lower bits in the PCED, through bit 0 to bit 3 must be zero in this field.                                             |

### 8.8.7.12 0x042C OHCI Bulk Current ED Register (Default Value:0x0000\_0000)

| Offset: 0x42C |            |     |             | Register Name: O_HcBulkCurrentED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------------|------------|-----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|               | HCD        | HC  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 31:4          | R/W        | R/W | 0x0         | BulkCurrentED [31:4]<br>This is advanced to the next ED after the HC has served the present one. HC continues processing the list from where it left off in the last Frame. When it reaches the end of the Bulk list, HC checks the ControlListFilled of HcControl. If set, it copies the content of HcBulkHeadED to HcBulkCurrentED and clears the bit. If it is not set, it does nothing. HCD is only allowed to modify this register when the BulkListEnable of HcControl is cleared. When set, the HCD only reads the instantaneous value of this register. This is initially set to zero to indicate the end of the Bulk list. |
| 3:0           | R          | R   | 0x0         | BulkCurrentED [3:0]<br>Because the general TD length is 16 bytes, the memory structure for the TD must be aligned to a 16-byte boundary. So the lower bits in the PCED, through bit 0 to bit 3 must be zero in this field.                                                                                                                                                                                                                                                                                                                                                                                                          |

#### 8.8.7.13 0x0430 OHCI Done Head Register (Default Value:0x0000\_0000)

| Offset: 0x0430 |            |     |             | Register Name: O_HcDoneHead                                                                                                                                                                                                                                                                                                     |
|----------------|------------|-----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                     |
|                | HCD        | HC  |             |                                                                                                                                                                                                                                                                                                                                 |
| 31:4           | R          | R/W | 0x0         | HcDoneHead [31:4]<br>When a TD is completed, HC writes the content of HcDoneHead to the NextTD field of the TD. HC then overwrites the content of HcDoneHead with the address of this TD. This is set to zero whenever HC writes the content of this register to HCCA. It also sets the WritebackDoneHead of HcInterruptStatus. |
| 3:0            | R          | R   | 0x0         | HcDoneHead [3:0]<br>Because the general TD length is 16 bytes, the memory structure for the TD must be aligned to a 16-byte boundary. So the lower bits in the PCED, through bit 0 to bit 3 must be zero in this field.                                                                                                         |

#### 8.8.7.14 0x0434 OHCI Frame Interval Register (Default Value:0x0000\_2EDF)

| Offset: 0x0434 |            |    |             | Register Name: O_HcFmInterval                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                              |
|                | HCD        | HC |             |                                                                                                                                                                                                                                                                                                                                                                          |
| 31             | R/W        | R  | 0x0         | FrameIntervalToggler<br>HCD toggles this bit whenever it loads a new value to FrameInterval.                                                                                                                                                                                                                                                                             |
| 30:16          | R/W        | R  | 0x0         | FSLargestDataPacket<br>This field specifies a value which is loaded into the Largest Data Packet Counter at the beginning of each frame. The counter value represents the largest amount of data in bits which can be sent or received by the HC in a single transaction at any given time without causing scheduling overrun. The field value is calculated by the HCD. |
| 15:14          | /          | /  | /           | /                                                                                                                                                                                                                                                                                                                                                                        |
| 13:0           | R/W        | R  | 0x2edf      | FrameInterval<br>This specifies the interval between two consecutive SOFs in bit times. The nominal value is set to be 11,999. HCD should store the current value of this field before resetting HC. By setting the HostControllerReset field of HcCommandStatus as this will cause the HC to reset this field to its                                                    |

| Offset: 0x0434 |            |    |             | Register Name: O_HcFmInterval                                                                        |
|----------------|------------|----|-------------|------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                                                                                          |
|                | HCD        | HC |             |                                                                                                      |
|                |            |    |             | nominal value. HCD may choose to restore the stored value upon the completion of the Reset sequence. |

#### 8.8.7.15 0x0438 OHCI Frame Remaining Register (Default Value:0x0000\_0000)

| Offset: 0x0438 |            |     |             | Register Name: O_HcFmRemaining                                                                                                                                                                                                                                                                                                                     |
|----------------|------------|-----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                        |
|                | HCD        | HC  |             |                                                                                                                                                                                                                                                                                                                                                    |
| 31             | R          | R/W | 0x0         | FrameRemaining Toggle<br>This bit is loaded from the FrameIntervalToggle field of HcFmInterval whenever FrameRemaining reaches 0. This bit is used by HCD for the synchronization between FrameInterval and FrameRemaining.                                                                                                                        |
| 30:14          | /          | /   | /           | /                                                                                                                                                                                                                                                                                                                                                  |
| 13:0           | R          | RW  | 0x0         | FrameRemaining<br>This counter is decremented at each bit time. When it reaches zero, it is reset by loading the FrameInterval value specified in HcFmInterval at the next bit time boundary. When entering the USBOPERATIONAL state, HC re-loads the content with the FrameInterval of HcFmInterval and uses the updated value from the next SOF. |

#### 8.8.7.16 0x043C OHCI Frame Number Register (Default Value:0x0000\_0000)

| Offset: 0x043C |            |     |             | Register Name: O_HcFmNumber                                                                                                                                                                                                                                                                                    |
|----------------|------------|-----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                    |
|                | HCD        | HC  |             |                                                                                                                                                                                                                                                                                                                |
| 31:16          | /          | /   | /           | /                                                                                                                                                                                                                                                                                                              |
| 15:0           | R          | R/W | 0x0         | FrameNumber<br>This is incremented when HcFmRemaining is re-loaded. It will be rolled over to 0x0 after 0xffff. When entering the USBOPERATIONAL state, this will be incremented automatically. The content will be written to HCCA after HC has incremented the FrameNumber at each frame boundary and sent a |

| Offset: 0x043C |            |    |             | Register Name: O_HcFmNumber                                                                                                   |
|----------------|------------|----|-------------|-------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                                                                                                                   |
|                | HCD        | HC |             |                                                                                                                               |
|                |            |    |             | SOF but before HC reads the first ED in that Frame. After writing to HCCA, HC will set the StartofFrame in HcInterruptStatus. |

#### 8.8.7.17 0x0440 OHCI Periodic Start Register (Default Value:0x0000\_0000)

| Offset: 0x0440 |            |    |             | Register Name: O_HcPeriodicStatus                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                | HCD        | HC |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 31:14          | /          | /  | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 13:0           | R/W        | R  | 0x0         | PeriodicStart<br>After a hardware reset, this field is cleared. This is then set by HCD during the HC initialization. The value is calculated roughly as 10% off from HcFmInterval. A typical value will be 0x2A3F (0x3e67). When HcFmRemaining reaches the value specified, processing of the periodic lists will have priority over Control/Bulk processing. HC will therefore start processing the Interrupt list after completing the current Control or Bulk transaction that is in progress. |

#### 8.8.7.18 0x0444 OHCI LS Threshold Register (Default Value:0x0000\_0628)

| Offset: 0x0444 |            |    |             | Register Name: O_HcLSThreshold                                                                                                                                                                                                                                                                             |
|----------------|------------|----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                                                                                                                                                                                                                                                                                                |
|                | HCD        | HC |             |                                                                                                                                                                                                                                                                                                            |
| 31:12          | /          | /  | /           | /                                                                                                                                                                                                                                                                                                          |
| 11:0           | R/W        | R  | 0x0628      | LSThreshold<br>This field contains a value which is compared to the FrameRemaining field prior to initiating a Low Speed transaction. The transaction is started only if FrameRemaining <sup>3</sup> this field. The value is calculated by HCD with the consideration of transmission and setup overhead. |

### 8.8.7.19 0x0448 OHCI Root Hub DescriptorA Register (Default Value:0x0200\_1201)

| Offset: 0x0448 |                                                                        |    |             | Register Name: O_HcRhDescriptorA                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |                                                                        |   |                                                    |
|----------------|------------------------------------------------------------------------|----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|------------------------------------------------------------------------|---|----------------------------------------------------|
| Bit            | Read/Write                                                             |    | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |                                                                        |   |                                                    |
|                | HCD                                                                    | HC |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |   |                                                                        |   |                                                    |
| 31:24          | R/W                                                                    | R  | 0x2         | <p>PowerOnToPowerGoodTime[POTPGT]</p> <p>This byte specifies the duration HCD has to wait before accessing a powered-on port of the Root Hub. It is implementation-specific. The unit of time is 2 ms. The duration is calculated as POTPGT * 2ms.</p>                                                                                                                                                                                                                                          |   |                                                                        |   |                                                    |
| 23:13          | /                                                                      | /  | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |   |                                                                        |   |                                                    |
| 12             | R/W                                                                    | R  | 1           | <p>NoOverCurrentProtection</p> <p>This bit describes how the overcurrent status for the Root Hub ports are reported. When this bit is cleared, the OverCurrentProtectionMode field specifies global or per-port reporting.</p> <table border="1"> <tr> <td>0</td><td>Over-current status is reported collectively for all downstream ports.</td></tr> <tr> <td>1</td><td>No overcurrent protection supported.</td></tr> </table>                                                                | 0 | Over-current status is reported collectively for all downstream ports. | 1 | No overcurrent protection supported.               |
| 0              | Over-current status is reported collectively for all downstream ports. |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |   |                                                                        |   |                                                    |
| 1              | No overcurrent protection supported.                                   |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |   |                                                                        |   |                                                    |
| 11             | R/W                                                                    | R  | 0           | <p>OverCurrentProtectionMode</p> <p>This bit describes how the overcurrent status for the Root Hub ports are reported. At reset, these fields should reflect the same mode as PowerSwitchingMode. This field is valid only if the NoOverCurrentProtection field is cleared.</p> <table border="1"> <tr> <td>0</td><td>Over-current status is reported collectively for all downstream ports.</td></tr> <tr> <td>1</td><td>Over-current status is reported on per-port basis.</td></tr> </table> | 0 | Over-current status is reported collectively for all downstream ports. | 1 | Over-current status is reported on per-port basis. |
| 0              | Over-current status is reported collectively for all downstream ports. |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |   |                                                                        |   |                                                    |
| 1              | Over-current status is reported on per-port basis.                     |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |   |                                                                        |   |                                                    |
| 10             | R                                                                      | R  | 0x0         | <p>Device Type</p> <p>This bit specifies that the Root Hub is not a compound device. The Root Hub is not permitted to be a compound device. This field should always read/write 0.</p>                                                                                                                                                                                                                                                                                                          |   |                                                                        |   |                                                    |
| 9              | R/W                                                                    | R  | 1           | <p>PowerSwitchingMode</p> <p>This bit is used to specify how the power switching of the Root Hub ports is controlled. It is implementation-specific. This field is only valid if the NoPowerSwitching field is cleared.</p> <table border="1"> <tr> <td>0</td><td>All ports are powered at the same time.</td></tr> </table>                                                                                                                                                                    | 0 | All ports are powered at the same time.                                |   |                                                    |
| 0              | All ports are powered at the same time.                                |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |   |                                                                        |   |                                                    |

| Offset: 0x0448 |                                                        |    |             | Register Name: O_HcRhDescriptorA                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                 |                           |   |                                                        |  |  |
|----------------|--------------------------------------------------------|----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------|---|--------------------------------------------------------|--|--|
| Bit            | Read/Write                                             |    | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                 |                           |   |                                                        |  |  |
|                | HCD                                                    | HC |             |                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                 |                           |   |                                                        |  |  |
|                |                                                        |    |             | 1                                                                                                                                                                                                                                                                                                                                                                                                                              | Each port is powered individually. This mode allows port power to be controlled by either the global switch or per-port switching. If the PortPowerControlMask bit is set, the port responds only to port power commands (Set/ClearPortPower). If the port mask is cleared, then the port is controlled only by the global power switch (Set/ClearGlobalPower). |                           |   |                                                        |  |  |
| 8              | R/W                                                    | R  | 0           | <p>NoPowerSwitching</p> <p>These bits are used to specify whether power switching is supported or ports are always powered. It is implementation-specific. When this bit is cleared, the PowerSwitchingMode specifies global or per-port switching.</p> <table border="1"> <tr> <td>0</td><td>Ports are power switched.</td></tr> <tr> <td>1</td><td>Ports are always powered on when the HC is powered on.</td></tr> </table> | 0                                                                                                                                                                                                                                                                                                                                                               | Ports are power switched. | 1 | Ports are always powered on when the HC is powered on. |  |  |
| 0              | Ports are power switched.                              |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                 |                           |   |                                                        |  |  |
| 1              | Ports are always powered on when the HC is powered on. |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                 |                           |   |                                                        |  |  |
| 7:0            | R                                                      | R  | 0x01        | <p>NumberDownstreamPorts</p> <p>These bits specify the number of downstream ports supported by the Root Hub. It is implementation-specific. The minimum number of ports is 1. The maximum number of ports supported.</p>                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                 |                           |   |                                                        |  |  |

#### 8.8.7.20 0x044C OHCI Root Hub DescriptorB Register (Default Value:0x0000\_0000)

| Offset: 0x044C |            |    |             | Register Name: O_HcRhDescriptorB |                                                                                                                                                                                                                                |  |
|----------------|------------|----|-------------|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bit            | Read/Write |    | Default/Hex | Description                      |                                                                                                                                                                                                                                |  |
|                | HCD        | HC |             |                                  |                                                                                                                                                                                                                                |  |
| 31:16          | R/W        | R  | 0x0         | PortPowerControlMask             | Each bit indicates if a port is affected by a global power control command when PowerSwitchingMode is set. When set, the port's power state is only affected by per-port power control (Set/ClearPortPower). When cleared, the |  |

| Offset: 0x044C |                                |    |             | Register Name: O_HcRhDescriptorB                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |          |      |                               |      |                               |     |  |       |                                |
|----------------|--------------------------------|----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|------|-------------------------------|------|-------------------------------|-----|--|-------|--------------------------------|
| Bit            | Read/Write                     |    | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                               |      |          |      |                               |      |                               |     |  |       |                                |
|                | HCD                            | HC |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |      |          |      |                               |      |                               |     |  |       |                                |
|                |                                |    |             | port is controlled by the global power switch (Set/ClearGlobalPower). If the device is configured to global switching mode (PowerSwitchingMode = 0), this field is not valid.                                                                                                                                                                                                                                                                                             |      |          |      |                               |      |                               |     |  |       |                                |
|                |                                |    |             | <table border="1"> <tr><td>Bit0</td><td>Reserved</td></tr> <tr><td>Bit1</td><td>Ganged-power mask on Port #1.</td></tr> <tr><td>Bit2</td><td>Ganged-power mask on Port #2.</td></tr> <tr><td>...</td><td></td></tr> <tr><td>Bit15</td><td>Ganged-power mask on Port #15.</td></tr> </table>                                                                                                                                                                               | Bit0 | Reserved | Bit1 | Ganged-power mask on Port #1. | Bit2 | Ganged-power mask on Port #2. | ... |  | Bit15 | Ganged-power mask on Port #15. |
| Bit0           | Reserved                       |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |      |          |      |                               |      |                               |     |  |       |                                |
| Bit1           | Ganged-power mask on Port #1.  |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |      |          |      |                               |      |                               |     |  |       |                                |
| Bit2           | Ganged-power mask on Port #2.  |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |      |          |      |                               |      |                               |     |  |       |                                |
| ...            |                                |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |      |          |      |                               |      |                               |     |  |       |                                |
| Bit15          | Ganged-power mask on Port #15. |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |      |          |      |                               |      |                               |     |  |       |                                |
| 15:0           | R/W                            | R  | 0x0         | <p>DeviceRemovable<br/>Each bit is dedicated to a port of the Root Hub.<br/>When cleared, the attached device is removable.<br/>When set, the attached device is not removable.</p> <table border="1"> <tr><td>Bit0</td><td>Reserved</td></tr> <tr><td>Bit1</td><td>Device attached to Port #1.</td></tr> <tr><td>Bit2</td><td>Device attached to Port #2.</td></tr> <tr><td>...</td><td></td></tr> <tr><td>Bit15</td><td>Device attached to Port #15.</td></tr> </table> | Bit0 | Reserved | Bit1 | Device attached to Port #1.   | Bit2 | Device attached to Port #2.   | ... |  | Bit15 | Device attached to Port #15.   |
| Bit0           | Reserved                       |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |      |          |      |                               |      |                               |     |  |       |                                |
| Bit1           | Device attached to Port #1.    |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |      |          |      |                               |      |                               |     |  |       |                                |
| Bit2           | Device attached to Port #2.    |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |      |          |      |                               |      |                               |     |  |       |                                |
| ...            |                                |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |      |          |      |                               |      |                               |     |  |       |                                |
| Bit15          | Device attached to Port #15.   |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |      |          |      |                               |      |                               |     |  |       |                                |

#### 8.8.7.21 0x0450 OHCI Root Hub Status Register (Default Value:0x0000\_0000)

| Offset: 0x0450 |            |    |             | Register Name: O_HcRhStatus                                                                                                                                                                                     |
|----------------|------------|----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                                                                                                                                                                                                     |
|                | HCD        | HC |             |                                                                                                                                                                                                                 |
| 31             | W          | R  | 0           | (write)ClearRemoteWakeUpEnable<br>Write a '1' clears DeviceRemoteWakeUpEnable.<br>Write a '0' has no effect.                                                                                                    |
| 30:18          | /          | /  | /           | /                                                                                                                                                                                                               |
| 17             | R/W        | R  | 0           | OverCurrentIndicatorChange<br>This bit is set by hardware when a change has occurred to the OverCurrentIndicator field of this register. The HCD clears this bit by writing a '1'. Writing a '0' has no effect. |
| 16             | R/W        | R  | 0x0         | (read)LocalPowerStartusChange<br>The Root Hub does not support the local power status features, thus, this bit is always read as '0'.<br>(write)SetGlobalPower<br>In global power mode (PowerSwitchingMode=0),  |

| Offset: 0x0450 |                                                   |     |             | Register Name: O_HcRhStatus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |   |                                                   |   |                                               |
|----------------|---------------------------------------------------|-----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------------------------------------------------|---|-----------------------------------------------|
| Bit            | Read/Write                                        |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |   |                                                   |   |                                               |
|                | HCD                                               | HC  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |                                                   |   |                                               |
|                |                                                   |     |             | This bit is written to '1' to turn on power to all ports (clear PortPowerStatus). In per-port power mode, it sets PortPowerStatus only on ports whose PortPowerControlMask bit is not set. Writing a '0' has no effect.                                                                                                                                                                                                                                                                                                                                                   |   |                                                   |   |                                               |
| 15             | R/W                                               | R   | 0x0         | <p>(read)DeviceRemoteWakeupEnable<br/>This bit enables a ConnectStatusChange bit as a resume event, causing a USBSUSPEND to USBRESUME state transition and setting the ResumeDetected interrupt.</p> <table border="1"> <tr> <td>0</td><td>ConnectStatusChange is not a remote wakeup event.</td></tr> <tr> <td>1</td><td>ConnectStatusChange is a remote wakeup event.</td></tr> </table> <p>(write)SetRemoteWakeupEnable<br/>Writing a '1' sets DeviceRemoveWakeupEnable.<br/>Writing a '0' has no effect.</p>                                                          | 0 | ConnectStatusChange is not a remote wakeup event. | 1 | ConnectStatusChange is a remote wakeup event. |
| 0              | ConnectStatusChange is not a remote wakeup event. |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |                                                   |   |                                               |
| 1              | ConnectStatusChange is a remote wakeup event.     |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |                                                   |   |                                               |
| 14:2           | /                                                 | /   | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |   |                                                   |   |                                               |
| 1              | R                                                 | R/W | 0x0         | <p>OverCurrentIndicator<br/>This bit reports overcurrent conditions when the global reporting is implemented. When set, an overcurrent condition exists. When cleared, all power operations are normal.<br/>If per-port overcurrent protection is implemented this bit is always '0'</p>                                                                                                                                                                                                                                                                                  |   |                                                   |   |                                               |
| 0              | R/W                                               | R   | 0x0         | <p>(Read)LocalPowerStatus<br/>When read, this bit returns the LocalPowerStatus of the Root Hub. The Root Hub does not support the local power status feature; thus, this bit is always read as '0'.<br/>(Write)ClearGlobalPower<br/>When write, this bit is operated as the ClearGlobalPower. In global power mode (PowerSwitchingMode=0), This bit is written to '1' to turn off power to all ports (clear PortPowerStatus). In per-port power mode, it clears PortPowerStatus only on ports whose PortPowerControlMask bit is not set. Writing a '0' has no effect.</p> |   |                                                   |   |                                               |

## 8.8.7.22 0x0454 OHCI Root Hub Port Status Register (Default Value:0x0000\_0100)

| Offset: 0x0454 |                                       |     |             | Register Name: O_HcRhPortStatus                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                                       |   |                                      |
|----------------|---------------------------------------|-----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------------------------------------|---|--------------------------------------|
| Bit            | Read/Write                            |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |                                       |   |                                      |
|                | HCD                                   | HC  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                                       |   |                                      |
| 31:21          | /                                     | /   | 0x0         | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                 |   |                                       |   |                                      |
| 20             | R/W                                   | R/W | 0x0         | <p>PortResetStatusChange<br/>This bit is set at the end of the 10-ms port reset signal. The HCD writes a '1' to clear this bit. Writing a '0' has no effect.</p> <table border="1"> <tr> <td>0</td><td>port reset is not complete</td></tr> <tr> <td>1</td><td>port reset is complete</td></tr> </table>                                                                                                                                                 | 0 | port reset is not complete            | 1 | port reset is complete               |
| 0              | port reset is not complete            |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                                       |   |                                      |
| 1              | port reset is complete                |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                                       |   |                                      |
| 19             | R/W                                   | R/W | 0x0         | <p>PortOverCurrentIndicatorChange<br/>This bit is valid only if overcurrent conditions are reported on a per-port basis. This bit is set when Root Hub changes the PortOverCurrentIndicator bit. The HCD writes a '1' to clear this bit. Writing a '0' has no effect.</p> <table border="1"> <tr> <td>0</td><td>no change in PortOverCurrentIndicator</td></tr> <tr> <td>1</td><td>PortOverCurrentIndicator has changed</td></tr> </table>               | 0 | no change in PortOverCurrentIndicator | 1 | PortOverCurrentIndicator has changed |
| 0              | no change in PortOverCurrentIndicator |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                                       |   |                                      |
| 1              | PortOverCurrentIndicator has changed  |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                                       |   |                                      |
| 18             | R/W                                   | R/W | 0x0         | <p>PortSuspendStatusChange<br/>This bit is set when the full resume sequence has been completed. This sequence includes the 20-s resume pulse, LS EOP, and 3-ms resynchronization delay. The HCD writes a '1' to clear this bit. Writing a '0' has no effect. This bit is also cleared when ResetStatusChange is set.</p> <table border="1"> <tr> <td>0</td><td>resume is not completed</td></tr> <tr> <td>1</td><td>resume completed</td></tr> </table> | 0 | resume is not completed               | 1 | resume completed                     |
| 0              | resume is not completed               |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                                       |   |                                      |
| 1              | resume completed                      |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                                       |   |                                      |
| 17             | R/W                                   | R/W | 0x0         | <p>PortEnableStatusChange<br/>This bit is set when hardware events cause the PortEnableStatus bit to be cleared. Changes from HCD writes do not set this bit. The HCD writes a '1' to clear this bit. Writing a '0' has no effect.</p> <table border="1"> <tr> <td>0</td><td>no change in PortEnableStatus</td></tr> <tr> <td>1</td><td>change in PortEnableStatus</td></tr> </table>                                                                    | 0 | no change in PortEnableStatus         | 1 | change in PortEnableStatus           |
| 0              | no change in PortEnableStatus         |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                                       |   |                                      |
| 1              | change in PortEnableStatus            |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                                       |   |                                      |
| 16             | R/W                                   | R/W | 0x0         | <p>ConnectStatusChange<br/>This bit is set whenever a connect or disconnect event occurs. The HCD writes a '1' to clear this bit. Writing a '0' has no effect. If</p>                                                                                                                                                                                                                                                                                    |   |                                       |   |                                      |

| Offset: 0x0454 |                               |     |             | Register Name: O_HcRhPortStatus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |                               |   |                            |
|----------------|-------------------------------|-----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|-------------------------------|---|----------------------------|
| Bit            | Read/Write                    |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |   |                               |   |                            |
|                | HCD                           | HC  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |                               |   |                            |
|                |                               |     |             | <p>CurrentConnectStatus is cleared when a SetPortReset, SetPortEnable, or SetPortSuspend write occurs, this bit is set to force the driver to re-evaluate the connection status since these writes should not occur if the port is disconnected.</p> <table border="1"> <tr> <td>0</td><td>no change in PortEnableStatus</td></tr> <tr> <td>1</td><td>change in PortEnableStatus</td></tr> </table> <p>Note: If the DeviceRemovable[NDP] bit is set, this bit is set only after a Root Hub reset to inform the system that the device is attached.</p>                                                                                                                 | 0 | no change in PortEnableStatus | 1 | change in PortEnableStatus |
| 0              | no change in PortEnableStatus |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |                               |   |                            |
| 1              | change in PortEnableStatus    |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |                               |   |                            |
| 15:10          | /                             | /   | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |                               |   |                            |
| 9              | R/W                           | R/W | -           | <p>(read)LowSpeedDeviceAttached<br/>This bit indicates the speed of the device attached to this port. When set, a Low Speed device is attached to this port. When clear, a Full Speed device is attached to this port. This field is valid only when the CurrentConnectStatus is set.</p> <table border="1"> <tr> <td>0</td><td>full speed device attached</td></tr> <tr> <td>1</td><td>low speed device attached</td></tr> </table> <p>(write)ClearPortPower<br/>The HCD clears the PortPowerStatus bit by writing a '1' to this bit. Writing a '0' has no effect.</p>                                                                                                | 0 | full speed device attached    | 1 | low speed device attached  |
| 0              | full speed device attached    |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |                               |   |                            |
| 1              | low speed device attached     |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |                               |   |                            |
| 8              | R/W                           | R/W | 0x1         | <p>(read)PortPowerStatus<br/>This bit reflects the port's power status, regardless of the type of power switching implemented. This bit is cleared if an overcurrent condition is detected. HCD sets this bit by writing SetPortPower or SetGlobalPower. HCD clears this bit by writing ClearPortPower or ClearGlobalPower. Which power control switches are enabled is determined by PowerSwitchingMode and PortPortControlMask[NumberDownstreamPort]. In global switching mode(PowerSwitchingMode=0), only Set/ClearGlobalPower controls this bit. In per-port power switching (PowerSwitchingMode=1), if the PortPowerControlMask[NDP] bit for the port is set,</p> |   |                               |   |                            |

| Offset: 0x0454 |                                 |     |             | Register Name: O_HcRhPortStatus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |                                 |   |                             |
|----------------|---------------------------------|-----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------------------------------|---|-----------------------------|
| Bit            | Read/Write                      |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |   |                                 |   |                             |
|                | HCD                             | HC  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |                                 |   |                             |
|                |                                 |     |             | <p>only Set/ClearPortPower commands are enabled. If the mask is not set, only Set/ClearGlobalPower commands are enabled. When port power is disabled, CurrentConnectStatus, PortEnableStatus, PortSuspendStatus, and PortResetStatus should be reset.</p> <table border="1"> <tr> <td>0</td><td>port power is off</td></tr> <tr> <td>1</td><td>port power is on</td></tr> </table> <p>(write)SetPortPower<br/>The HCD writes a '1' to set the PortPowerStatus bit. Writing a '0' has no effect.</p> <p>Note: This bit is always reads '1b' if power switching is not supported.</p>                                                                                                                                                         | 0 | port power is off               | 1 | port power is on            |
| 0              | port power is off               |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |                                 |   |                             |
| 1              | port power is on                |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |                                 |   |                             |
| 7:5            | /                               | /   | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |                                 |   |                             |
| 4              | R/W                             | R/W | 0x0         | <p>(read)PortResetStatus<br/>When this bit is set by a write to SetPortReset, port reset signaling is asserted. When reset is completed, this bit is cleared when PortResetStatusChange is set. This bit cannot be set if CurrentConnectStatus is cleared.</p> <table border="1"> <tr> <td>0</td><td>port reset signal is not active</td></tr> <tr> <td>1</td><td>port reset signal is active</td></tr> </table> <p>(write)SetPortReset<br/>The HCD sets the port reset signaling by writing a '1' to this bit. Writing a '0' has no effect. If CurrentConnectStatus is cleared, this write does not set PortResetStatus, but instead sets ConnectStatusChange. This informs the driver that it attempted to reset a disconnected port.</p> | 0 | port reset signal is not active | 1 | port reset signal is active |
| 0              | port reset signal is not active |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |                                 |   |                             |
| 1              | port reset signal is active     |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |                                 |   |                             |
| 3              | R/W                             | R/W | 0x0         | <p>(read)PortOverCurrentIndicator<br/>This bit is only valid when the Root Hub is configured in such a way that overcurrent conditions are reported on a per-port basis. If per-port overcurrent reporting is not supported, this bit is set to 0. If cleared, all power operations are normal for this port. If set, an overcurrent</p>                                                                                                                                                                                                                                                                                                                                                                                                    |   |                                 |   |                             |

| Offset: 0x0454 |                                 |     |             | Register Name: O_HcRhPortStatus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |                           |   |                                 |
|----------------|---------------------------------|-----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------------------------|---|---------------------------------|
| Bit            | Read/Write                      |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |   |                           |   |                                 |
|                | HCD                             | HC  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |                           |   |                                 |
|                |                                 |     |             | <p>condition exists on this port. This bit always reflects the overcurrent input signal.</p> <table border="1"> <tr> <td>0</td><td>no overcurrent condition.</td></tr> <tr> <td>1</td><td>overcurrent condition detected.</td></tr> </table> <p>(write)ClearSuspendStatus<br/>The HCD writes a '1' to initiate a resume. Writing a '0' has no effect. A resume is initiated only if PortSuspendStatus is set.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0 | no overcurrent condition. | 1 | overcurrent condition detected. |
| 0              | no overcurrent condition.       |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |                           |   |                                 |
| 1              | overcurrent condition detected. |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |                           |   |                                 |
| 2              | R/W                             | R/W | 0x0         | <p>(read)PortSuspendStatus<br/>This bit indicates the port is suspended or in the resume sequence. It is set by a SetSuspendState write and cleared when PortSuspendStatusChange is set at the end of the resume interval. This bit cannot be set if CurrentConnectStatus is cleared. This bit is also cleared when PortResetStatusChange is set at the end of the port reset or when the HC is placed in the USBRESUME state. If an upstream resume is in progress, it should propagate to the HC.</p> <table border="1"> <tr> <td>0</td><td>port is not suspended</td></tr> <tr> <td>1</td><td>port is suspended</td></tr> </table> <p>(write)SetPortSuspend<br/>The HCD sets the PortSuspendStatus bit by writing a '1' to this bit. Writing a '0' has no effect. If CurrentConnectStatus is cleared, this write does not set PortSuspendStatus; instead it sets ConnectStatusChange. This informs the driver that it attempted to suspend a disconnected port.</p> | 0 | port is not suspended     | 1 | port is suspended               |
| 0              | port is not suspended           |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |                           |   |                                 |
| 1              | port is suspended               |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |                           |   |                                 |
| 1              | R/W                             | R/W | 0x0         | <p>(read)PortEnableStatus<br/>This bit indicates whether the port is enabled or disabled. The Root Hub may clear this bit when an overcurrent condition, disconnect event, switched-off power, or operational bus error such as babble is detected. This change also causes PortEnabledStatusChange to be set. HCD sets this bit by writing SetPortEnable and clears it by writing ClearPortEnable. This bit cannot be set when CurrentConnectStatus is cleared. This bit is also set,</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |                           |   |                                 |

| Offset: 0x0454 |                     |     |             | Register Name: O_HcRhPortStatus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                     |   |                  |
|----------------|---------------------|-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------------------|---|------------------|
| Bit            | Read/Write          |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |                     |   |                  |
|                | HCD                 | HC  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                     |   |                  |
|                |                     |     |             | <p>if not already, at the completion of a port reset when ResetStatusChange is set or port suspend when SuspendStatusChange is set.</p> <table border="1"> <tr> <td>0</td><td>port is disabled</td></tr> <tr> <td>1</td><td>port is enabled</td></tr> </table> <p>(write)SetPortEnable<br/>The HCD sets PortEnableStatus by writing a '1'. Writing a '0' has no effect. If CurrentConnectStatus is cleared, this write does not set PortEnableStatus, but instead sets ConnectStatusChange. This informs the driver that it attempted to enable a disconnected Port.</p> | 0 | port is disabled    | 1 | port is enabled  |
| 0              | port is disabled    |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                     |   |                  |
| 1              | port is enabled     |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                     |   |                  |
| 0              | R/W                 | R/W | 0x0         | <p>(read)CurrentConnectStatus<br/>This bit reflects the current state of the downstream port.</p> <table border="1"> <tr> <td>0</td><td>No device connected</td></tr> <tr> <td>1</td><td>Device connected</td></tr> </table> <p>(write)ClearPortEnable<br/>The HCD writes a '1' to clear the PortEnableStatus bit. Writing '0' has no effect. The CurrentConnectStatus is not affected by any write.</p> <p>Note: This bit is always read '1' when the attached device is nonremovable(DeviceRemovable[NumberDownstreamPort]).</p>                                       | 0 | No device connected | 1 | Device connected |
| 0              | No device connected |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                     |   |                  |
| 1              | Device connected    |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                     |   |                  |

## 8.8.8 HCI Controller and PHY Interface Description

### 8.8.8.1 0x0800 HCI Interface Register (Default Value:0x0000\_0000)

| Offset: 0x0800 |            |             | Register Name: USB_CTRL                                                                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                        |
| 31             | R/W        | 0x0         | USB Standby Clock Sel<br>0x0: normal mode USB clock as usual<br>0x1: standby mode USB clock switch to RC 16M clock |

| Offset: 0x0800 |            |             | Register Name: USB_CTRL                                                                                                                                                                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                        |
| 30:29          | /          | /           | /                                                                                                                                                                                                                                                  |
| 28             | R          | 1           | DMA Transfer Status Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                              |
| 27:26          | /          | /           | /                                                                                                                                                                                                                                                  |
| 25             | R/W        | 0           | OHCI count select<br>1: Simulation mode, the counters will be much shorter then real time<br>0: Normal mode, the counters will count full time                                                                                                     |
| 24             | R/W        | 0           | Simulation mode<br>1: Set PHY in a non-driving mode so the EHCI can detect device connection, this is used only for simulation<br>0: No effect                                                                                                     |
| 23:21          | /          | /           | /                                                                                                                                                                                                                                                  |
| 20             | R/W        | 0           | EHCI HS force<br>Set 1 to this field force the EHCI enter the high speed mode during bus reset.<br>This field only valid when the bit 1 is set.                                                                                                    |
| 19             | /          | /           | /                                                                                                                                                                                                                                                  |
| 18             | R/W        | 0           | 1: within 2us of the Resume-K to SE0 transition<br>0: random time value of the resume-K to SE0 transition                                                                                                                                          |
| 17:13          | /          | /           | /                                                                                                                                                                                                                                                  |
| 12             | R/W        | 0           | PP2VBUS<br>1: ULPI wrapper interface will automatically set or clear DrvVbus register in ULPI PHY according to the port power status form the root hub<br>0: ULPI wrapper will ignore the difference between power status of root hub and ULPI PHY |
| 11             | R/W        | 0           | AHB Master interface INCR16 enable<br>1: Use INCR16 when appropriate<br>0: do not use INCR16,use other enabled INCRX or unspecified length burst INCR                                                                                              |
| 10             | R/W        | 0           | AHB Master interface INCR8 enable<br>1: Use INCR8 when appropriate<br>0: do not use INCR8,use other enabled INCRX or unspecified length burst INCR                                                                                                 |
| 9              | R/W        | 0           | AHB Master interface burst type INCR4 enable<br>1: Use INCR4 when appropriate<br>0: do not use INCR4,use other enabled INCRX or                                                                                                                    |

| Offset: 0x0800 |            |             | Register Name: USB_CTRL                                                                                                                                                                                 |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                             |
|                |            |             | unspecified length burst INCR                                                                                                                                                                           |
| 8              | R/W        | 0           | AHB Master interface INCRX align enable<br>1: start INCRx burst only on burst x-align address<br>0: Start burst on any double word boundary<br>Note: This bit must enable if any bit of 11:9 is enabled |
| 7:4            | /          | /           | /                                                                                                                                                                                                       |
| 3              | R/W        | 0x0         | RC Clock Gating<br>0x0: clock gated<br>0x1: clock ungated                                                                                                                                               |
| 2              | R/W        | 0x0         | RC Generation Enable<br>0x0: disable<br>0x1: enable                                                                                                                                                     |
| 1              | /          | /           | /                                                                                                                                                                                                       |
| 0              | R/W        | 0           | ULPI bypass enable.<br>1: Enable UTMI interface, disable ULPI interface<br>0: Enable ULPI interface, disable UTMI interface                                                                             |

#### 8.8.8.2 0x0808 HCI Control 3 Register (Default Value:0x0000\_0000)

| Offset: 0x0808 |            |             | Register Name: HCI_CTRL3                                                                                                   |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                |
| 31:17          | /          | /           | Reserved.                                                                                                                  |
| 16             | R/W1C      | 0           | Linestate Change Detect<br>0: Linestate change not detected.<br>1: Linestate change detected.<br>Write '1' to clear.       |
| 15:10          | /          | /           | Reserved.                                                                                                                  |
| 9              | R/W        | 0           | Forcesusp<br>1: Susp_Sel is valid. PHY could be configured into suspend mode when Susp_Sel = 0.<br>0: Susp_Sel is invalid. |
| 8              | R/W        | 0           | Susp_Sel<br>1: Normal operating mode (PHY)<br>0: Suspend Mode (PHY)<br>This bit is valid when forcesusp=1.                 |
| 7:4            | /          | /           | /                                                                                                                          |
| 3              | R/W        | 0           | Remote Wakeup Enable<br>1: Enable<br>0: Disable                                                                            |

| Offset: 0x0808 |            |             | Register Name: HCI_CTRL3                                     |
|----------------|------------|-------------|--------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                  |
| 2              | /          | /           | Reserved.                                                    |
| 1              | R/W        | 0           | Linestate Change Interrupt Enable<br>1: Enable<br>0: Disable |
| 0              | R/W        | 0           | Linestate Change Detect Enable<br>1: Enable<br>0: Disable    |

#### 8.8.8.3 0x0810 PHY Control Register (Default Value: 0x0000\_0018)

| Offset: 0x0810 |            |             | Register Name: PHY_CTL                                           |
|----------------|------------|-------------|------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                      |
| 31:9           | /          | /           | /                                                                |
| 8              | R/W        | 0           | VREGBYPASS                                                       |
| 7              | R/W        | 0           | LOOPBACKENB                                                      |
| 6              | R/W        | 0           | IDPULLUP                                                         |
| 5              | R/W        | 0           | VBUSVLDEXT                                                       |
| 4              | R/W        | 1           | VBUSVLDEXTSEL                                                    |
| 3              | R/W        | 1           | SIDDQ<br>1: Write 1 to disable PHY.<br>0: Write 0 to enable PHY. |
| 2              | R/W        | 0           | COMMONN                                                          |
| 1:0            | R/W        | 0           | VATESTENB                                                        |

#### 8.8.8.4 0x0814 PHY Test Register (Default Value: 0x0000\_0000)

| Offset: 0x0814 |            |             | Register Name: PHY_TEST |
|----------------|------------|-------------|-------------------------|
| Bit            | Read/Write | Default/Hex | Description             |
| 31:15          | /          | /           | /                       |
| 14             | R/W        | 0x0         | TESTBURNIN              |
| 13             | R/W        | 0x0         | TESTDATAOUTSEL          |
| 12             | R/W        | 0x0         | TESTCLK                 |
| 11:8           | R/W        | 0x0         | TESTADDR                |
| 7:0            | R/W        | 0x0         | TESTDATAIN              |

#### 8.8.8.5 0x0818 PHY Tune Register (Default Value: 0x05B3\_33D4)

| Offset: 0x0818 |            |             | Register Name: PHY_TUNE |
|----------------|------------|-------------|-------------------------|
| Bit            | Read/Write | Default/Hex | Description             |

| Offset: 0x0818 |            |             | Register Name: PHY_TUNE |
|----------------|------------|-------------|-------------------------|
| Bit            | Read/Write | Default/Hex | Description             |
| 31:28          | /          | /           | /                       |
| 27:26          | R/W        | 0x1         | VDATREFTUNE[1:0]        |
| 25:23          | R/W        | 0x3         | COMPDISTUNE[2:0]        |
| 22:20          | R/W        | 0x3         | SQRXTUNE[2:0]           |
| 19             | R/W        | 0x0         | TXPREEMPPULSETUNE       |
| 18:16          | R/W        | 0x3         | OTGTUNE[2:0]            |
| 15:12          | R/W        | 0x3         | TXFSLSTUNE[3:0]         |
| 11:8           | R/W        | 0x3         | TXVREFTUNE[3:0]         |
| 7:6            | R/W        | 0x3         | TXHSXVTUNE[1:0]         |
| 5:4            | R/W        | 0x1         | TXRISETUNE[1:0]         |
| 3:2            | R/W        | 0x1         | TXRESTUNE[1:0]          |
| 1:0            | R/W        | 0x0         | TXPREEMPAMPTUNE[1:0]    |

#### 8.8.8.6 0x0824 PHY Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0824 |            |             | Register Name: PHY_STA |
|----------------|------------|-------------|------------------------|
| Bit            | Read/Write | Default/Hex | Description            |
| 31:4           | /          | /           | /                      |
| 3:0            | R          | 0           | TESTDATAOUT            |

#### 8.8.8.7 0x0828 HCI SIE Port Disable Control Register (Default Value:0x0000\_0003)

| Offset: 0x0828 |            |             | Register Name: USB_SPDCR                                                                                                                                                                                                                               |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                            |
| 31:17          | /          | /           | /                                                                                                                                                                                                                                                      |
| 16             | R/W        | 0           | SE0 Status<br>This bit is set when no-se0 is detected before SOF when bit[1:0] is 10b or 11b                                                                                                                                                           |
| 15:5           | /          | /           | /                                                                                                                                                                                                                                                      |
| 4              | R/W        | 0           | resume_sel<br>When set k-se0 transition 2us, setting this bit to 1, which is cooperated with ss_utmi_backward_enb_i.                                                                                                                                   |
| 3:2            | /          | /           | /                                                                                                                                                                                                                                                      |
| 1:0            | R/W        | 0x3         | Port Disable Control<br>00: Port Disable when no-se0 detect before SOF<br>01: Port Disable when no-se0 detect before SOF<br>10: No Port Disable when no-se0 detect before SOF<br>11: Port Disable when no-se0 3 time detect before SOF during 8 Frames |

## 8.9 USB2.0 HOST

### 8.9.1 Overview

The USB Host Controller is fully compliant with USB 2.0 Specification, Enhanced Host Controller Interface (EHCI) Specification Revision 1.0 and Open Host Controller Interface (OHCI) Specification Release 1.0a.

The USB2.0 host controller includes the following features:

- One USB 2.0 HOST (USB1), with integrated USB 2.0 analog PHY
- Industry-standard AMBA High-Performance Bus (AHB), fully compliant with the AMBA Specification, Revision 2.0.
- 32-bit Little Endian AMBA AHB Slave Bus for Register Access
- 32-bit Little Endian AMBA AHB Master Bus for Memory Access
- An internal DMA Controller for data transfer with memory
- Compatible with Enhanced Host Controller Interface (EHCI) Specification, Version 1.0
- Compatible with Open Host Controller Interface (OHCI) Specification, Version 1.0a
- Supports High-Speed (HS, 480 Mbit/s), Full-Speed (FS, 12 Mbit/s) and Low-Speed (LS, 1.5 Mbit/s) Device
- Supports the UTMI+ Level 3 interface and 8-bit bidirectional data buses
- Supports only 1 USB Root port shared between EHCI and OHCI

### 8.9.2 Block Diagram

The following figure shows the block diagram of USB2.0 Host Controller.

Figure 8-38 USB2.0 Host Controller Block Diagram



### 8.9.3 Functional Description

#### 8.9.3.1 External Signals

Table 8-30 USB2.0 Host External Signals

| Signal Name | Description                           | Type  |
|-------------|---------------------------------------|-------|
| USB1-DM     | USB2.0 Data Signal DM                 | A I/O |
| USB1-DP     | USB2.0 Data Signal DP                 | A I/O |
| USB1-REXT   | USB2.0 External Reference Resistor AO | AO    |

#### 8.9.3.2 Controller and PHY Connection Diagram

Figure 8-39 USB2.0 Host Controller and PHY Connection Diagram



### 8.9.4 Register List

| Module Name | Base Address |
|-------------|--------------|
| USB1        | 0x04200000   |

| Register Name                    | Offset | Description                                     |
|----------------------------------|--------|-------------------------------------------------|
| <b>EHCI Capability Register</b>  |        |                                                 |
| E_CAPLENGTH                      | 0x0000 | EHCI Capability register Length Register        |
| E_HCIVERSION                     | 0x0002 | EHCI Host Interface Version Number Register     |
| E_HCSPARAMS                      | 0x0004 | EHCI Host Control Structural Parameter Register |
| E_HCCPARAMS                      | 0x0008 | EHCI Host Control Capability Parameter Register |
| E_HCSPPORTROUTE                  | 0x000c | EHCI Companion Port Route Description           |
| <b>EHCI Operational Register</b> |        |                                                 |
| E_USBCMD                         | 0x0010 | EHCI USB Command Register                       |
| E_USBSTS                         | 0x0014 | EHCI USB Status Register                        |
| E_USBINTR                        | 0x0018 | EHCI USB Interrupt Enable Register              |

| Register Name                                     | Offset | Description                                  |
|---------------------------------------------------|--------|----------------------------------------------|
| E_FRINDEX                                         | 0x001C | EHCI USB Frame Index Register                |
| E_CTRLDSSEGMENT                                   | 0x0020 | EHCI 4G Segment Selector Register            |
| E_PERIODICLISTBASE                                | 0x0024 | EHCI Frame List Base Address Register        |
| E_ASYNCLISTADDR                                   | 0x0028 | EHCI Next Asynchronous List Address Register |
| E_CONFIGFLAG                                      | 0x0050 | EHCI Configured Flag Register                |
| E_PORTSC                                          | 0x0054 | EHCI Port Status/Control Register            |
| <b>OHCI Control and Status Partition Register</b> |        |                                              |
| O_HcControl                                       | 0x0404 | OHCI Control Register                        |
| O_HcCommandStatus                                 | 0x0408 | OHCI Command Status Register                 |
| O_HcInterruptStatus                               | 0x040C | OHCI Interrupt Status Register               |
| O_HcInterruptEnable                               | 0x0410 | OHCI Interrupt Enable Register               |
| O_HcInterruptDisable                              | 0x0414 | OHCI Interrupt Disable Register              |
| <b>OHCI Memory Pointer Partition Register</b>     |        |                                              |
| O_HcHCCA                                          | 0x0418 | OHCI HCCA Base                               |
| O_HcPeriodCurrentED                               | 0x041C | OHCI Period Current ED Base                  |
| O_HcControlHeadED                                 | 0x0420 | OHCI Control Head ED Base                    |
| O_HcControlCurrentED                              | 0x0424 | OHCI Control Current ED Base                 |
| O_HcBulkHeadED                                    | 0x0428 | OHCI Bulk Head ED Base                       |
| O_HcBulkCurrentED                                 | 0x042C | OHCI Bulk Current ED Base                    |
| O_HcDoneHead                                      | 0x0430 | OHCI Done Head Base                          |
| <b>OHCI Frame Counter Partition Register</b>      |        |                                              |
| O_HcFmInterval                                    | 0x0434 | OHCI Frame Interval Register                 |
| O_HcFmRemaining                                   | 0x0438 | OHCI Frame Remaining Register                |
| O_HcFmNumber                                      | 0x043C | OHCI Frame Number Register                   |
| O_HcPeriodicStart                                 | 0x0440 | OHCI Periodic Start Register                 |
| O_HcLSThreshold                                   | 0x0444 | OHCI LS Threshold Register                   |
| <b>OHCI Root Hub Partition Register</b>           |        |                                              |
| O_HcRhDescriptorA                                 | 0x0448 | OHCI Root Hub Descriptor Register A          |
| O_HcRhDescriptorB                                 | 0x044C | OHCI Root Hub Descriptor Register B          |
| O_HcRhStatus                                      | 0x0450 | OHCI Root Hub Status Register                |
| O_HcRhPortStatus                                  | 0x0454 | OHCI Root Hub Port Status Register           |
| <b>HCI Controller and PHY Interface Register</b>  |        |                                              |
| USB_CTRL                                          | 0x0800 | HCI Interface Register                       |
| HCI_CTRL3                                         | 0x0808 | HCI Control 3 Register                       |
| PHY_CTRL                                          | 0x0810 | PHY Control Register                         |
| PHY_TEST                                          | 0x0814 | PHY Test Register                            |
| PHY_TUNE                                          | 0x0818 | PHY Tune Register                            |
| PHY_STA                                           | 0x0824 | PHY Status Register                          |
| USB_SPDCR                                         | 0x0828 | HCI SIE Port Disable Control Register        |

## 8.9.5 EHCI Register Description

### 8.9.5.1 0x0000 EHCI Identification Register (Default Value:0x10)

| Offset:0x0000 |            |             | Register Name: E_CAPLENGTH                                                                                                                |
|---------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                               |
| 7:0           | R          | 0x10        | CAPLENGTH<br>The value in these bits indicates an offset to add to register base to find the beginning of the Operational Register Space. |

### 8.9.5.2 0x0002 EHCI Host Interface Version Number Register (Default Value:0x0100)

| Offset: 0x0002 |            |             | Register Name: E_HCIVERSION                                                                                                                                                                                                                                   |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                   |
| 15:0           | R          | 0x0100      | HCIVERSION<br>This is a 16-bit register containing a BCD encoding of the EHCI revision number supported by this host controller. The most significant byte of this register represents a major revision and the least significant byte is the minor revision. |

### 8.9.5.3 0x0004 EHCI Host Control Structural Parameter Register (Default Value:0x0000\_1101)

| Offset: 0x0004 |            |             | Register Name: E_HCSPARAMS                                                                                                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                  |
| 31:24          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                            |
| 23:20          | R          | 0x0         | Debug Port Number<br>This register identifies which of the host controller ports is the debug port. The value is the port number (one based) of the debug port.<br>This field will always be '0'.                                                                                                                                                            |
| 19:16          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                            |
| 15:12          | R          | 0x1         | Number of Companion Controller (N_CC)<br>This field indicates the number of companion controllers associated with this USB2.0 host controller. A zero in this field indicates there are no companion host controllers. And a value larger than zero in this field indicates there are companion USB1.1 host controller(s).<br>This field will always be '0'. |
| 11:8           | R          | 0x1         | Number of Port per Companion Controller (N_PCC)                                                                                                                                                                                                                                                                                                              |

| Offset: 0x0004 |                                                                                                                                                                                         |             | Register Name: E_HCSPARAMS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write                                                                                                                                                                              | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |
|                |                                                                                                                                                                                         |             | <p>This field indicates the number of ports supported per companion host controller host controller. It is used to indicate the port routing configuration to system software.</p> <p>This field will always fix with '0'.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |
| 7              | R                                                                                                                                                                                       | 0x0         | <p>Port Routing Rules</p> <p>This field indicates the method used by this implementation for how all ports are mapped to companion controllers. The value of this field has the following interpretation:</p> <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>The first N_PCC ports are routed to the lowest numbered function companion host controller, the next N_PCC port are routed to the next lowest function companion controller, and so on.</td></tr> <tr> <td>1</td><td>The port routing is explicitly enumerated by the first N_PORTS elements of the HCSP-PORTTOUTE array.</td></tr> </tbody> </table> <p>This field will always be '0'.</p> | Value | Meaning | 0 | The first N_PCC ports are routed to the lowest numbered function companion host controller, the next N_PCC port are routed to the next lowest function companion controller, and so on. | 1 | The port routing is explicitly enumerated by the first N_PORTS elements of the HCSP-PORTTOUTE array. |
| Value          | Meaning                                                                                                                                                                                 |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |
| 0              | The first N_PCC ports are routed to the lowest numbered function companion host controller, the next N_PCC port are routed to the next lowest function companion controller, and so on. |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |
| 1              | The port routing is explicitly enumerated by the first N_PORTS elements of the HCSP-PORTTOUTE array.                                                                                    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |
| 6:4            | /                                                                                                                                                                                       | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |
| 3:0            | R                                                                                                                                                                                       | 0x1         | <p>N_PORTS</p> <p>This field specifies the number of physical downstream ports implemented on this host controller. The value of this field determines how many port registers are addressable in the Operational Register Space. Valid values are in the range of 0x1 to 0x0f.</p> <p>This field is always 1.</p>                                                                                                                                                                                                                                                                                                                                                                                                |       |         |   |                                                                                                                                                                                         |   |                                                                                                      |

#### 8.9.5.4 0x0008 EHCI Host Control Capability Parameter Register (Default Value:0x0000\_A026)

| Offset: 0x0008 |            |             | Register Name: E_HCCPARAMS                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                      |
| 31:16          | /          | /           | /                                                                                                                                                                                                                                                                                |
| 15:8           | R          | 0xA0        | <p>EHCI Extended Capabilities Pointer (EECP)</p> <p>This optional field indicates the existence of a capabilities list. A value of 00b indicates no extended capabilities are implemented. A non-zero value in this register indicates the offset in PCI configuration space</p> |

| Offset: 0x0008 |            |             | Register Name: E_HCCPARAMS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                |            |             | of the first EHCI extended capability. The pointer value must be 40h or greater if implemented to maintain consistency of the PCI header defined for this class of device.<br>The value of this field is always '00b'.                                                                                                                                                                                                                                                                                                                                     |
| 7:4            | R          | 0x2         | Isochronous Scheduling Threshold<br>This field indicates, relative to the current position of the executing host controller, where software can reliably update the isochronous schedule.<br>When bit[7] is zero, the value of the least significant 3 bits indicates the number of micro-frames a host controller can hold a set of isochronous data structures(one or more) before flushing the state.<br>When bit[7] is a one, then host software assumes the host controller may cache an isochronous data structure for an entire frame.              |
| 3              | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 2              | R          | 0x1         | Asynchronous Schedule Park Capability<br>If this bit is set to a one, then the host controller supports the park feature for high-speed queue heads in the Asynchronous Schedule. The feature can be disabled or enabled and set to a specific level by using the Asynchronous Schedule Park Mode Enable and Asynchronous Schedule Park Mode Count fields in the USBCMD register.                                                                                                                                                                          |
| 1              | R          | 0x1         | Programmable Frame List Flag<br>If this bit is set to a zero, then system software must use a frame list length of 1024 elements with this host controller. The USBCMD register Frame List Size field is a read-only register and should be set to zero.<br>If set to 1, then system software can specify and use the frame list in the USBCMD register Frame List Size field to configure the host controller.<br>The frame list must always aligned on a 4K page boundary. This requirement ensures that the frame list is always physically contiguous. |
| 0              | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

#### 8.9.5.5 0x000C EHCI Companion Port Route Description (Default Value:0x0000\_0000)

| Offset: 0x000C | Register Name: E_HCSP-PORTROUTE |
|----------------|---------------------------------|
|----------------|---------------------------------|

| Bit  | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | R          | 0x0         | <p>HCSP-PORTROUTE</p> <p>This optional field is valid only if Port Routing Rules field in HCSPARAMS register is set to a one.</p> <p>This field is used to allow a host controller implementation to explicitly describe to which companion host controller each implemented port is mapped. This field is a 15-element nibble array (each 4 bit is one array element). Each array location corresponds one-to-one with a physical port provided by the host controller (e.g. PORTROUTE [0] corresponds to the first PORTSC port, PORTROUTE [1] to the second PORTSC port, etc.). The value of each element indicates to which the companion host controllers this port is routed. Only the first N_PORTS elements have valid information. A value of zero indicates that the port is routed to the lowest numbered function companion host controller. A value of one indicates that the port is routed to the next lowest numbered function companion host controller, and so on.</p> |

#### 8.9.5.6 0x0010 EHCI USB Command Register (Default Value:0x0008\_0B00)

| Offset: 0x0010 |                                         |             | Register Name: E_USBCMD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
|----------------|-----------------------------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|----------------------------|------|----------|------|---------------|------|---------------|------|---------------|------|-----------------------------------------|------|---------------------|------|---------------------|------|---------------------|
| Bit            | Read/Write                              | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 31:24          | /                                       | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 23:16          | R/W                                     | 0x08        | <p>Interrupt Threshold Control</p> <p>The value in this field is used by system software to select the maximum rate at which the host controller will issue interrupts. The only valid values are defined below:</p> <table border="1"> <thead> <tr> <th>Value</th><th>Minimum Interrupt Interval</th></tr> </thead> <tbody> <tr> <td>0x00</td><td>Reserved</td></tr> <tr> <td>0x01</td><td>1 micro-frame</td></tr> <tr> <td>0x02</td><td>2 micro-frame</td></tr> <tr> <td>0x04</td><td>4 micro-frame</td></tr> <tr> <td>0x08</td><td>8 micro-frame(default, equates to 1 ms)</td></tr> <tr> <td>0x10</td><td>16 micro-frame(2ms)</td></tr> <tr> <td>0x20</td><td>32 micro-frame(4ms)</td></tr> <tr> <td>0x40</td><td>64 micro-frame(8ms)</td></tr> </tbody> </table> | Value | Minimum Interrupt Interval | 0x00 | Reserved | 0x01 | 1 micro-frame | 0x02 | 2 micro-frame | 0x04 | 4 micro-frame | 0x08 | 8 micro-frame(default, equates to 1 ms) | 0x10 | 16 micro-frame(2ms) | 0x20 | 32 micro-frame(4ms) | 0x40 | 64 micro-frame(8ms) |
| Value          | Minimum Interrupt Interval              |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x00           | Reserved                                |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x01           | 1 micro-frame                           |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x02           | 2 micro-frame                           |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x04           | 4 micro-frame                           |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x08           | 8 micro-frame(default, equates to 1 ms) |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x10           | 16 micro-frame(2ms)                     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x20           | 32 micro-frame(4ms)                     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |
| 0x40           | 64 micro-frame(8ms)                     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |       |                            |      |          |      |               |      |               |      |               |      |                                         |      |                     |      |                     |      |                     |

| Offset: 0x0010 |            |             | Register Name: E_USBCMD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                |            |             | <p>Any other value in this register yields undefined results.</p> <p>The default value in this field is 0x08 .</p> <p>Software modifications to this bit while HC Halted bit is equal to zero results in undefined behavior.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 15:12          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 11             | R          | 0x1         | <p>Asynchronous Schedule Park Mode Enable (OPTIONAL)</p> <p>If the Asynchronous Park Capability bit in the HCCPARAMS register is a one, then this bit defaults to a 1 and is R/W. Otherwise the bit must be a zero and is Read Only. Software uses this bit to enable or disable Park mode. When this bit is one, Park mode is enabled. When this bit is zero, Park mode is disabled.</p>                                                                                                                                                                                                                                                                                     |
| 10             | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 9:8            | R          | 0x3         | <p>Asynchronous Schedule Park Mode Count (OPTIONAL)</p> <p>Asynchronous Park Capability bit in the HCCPARAMS register is a one, then this field defaults to 0x3 and is W/R. Otherwise it defaults to zero and is R. It contains a count of the number of successive transactions the host controller is allowed to execute from a high-speed queue head on the Asynchronous schedule before continuing traversal of the Asynchronous schedule.</p> <p>Valid value are 0x1 to 0x3. Software must not write a zero to this bit when Park Mode Enable is a one as it will result in undefined behavior.</p>                                                                      |
| 7              | R/W        | 0x0         | <p>Light Host Controller Reset (OPTIONAL)</p> <p>This control bit is not required.</p> <p>If implemented, it allows the driver to reset the EHCI controller without affecting the state of the ports or relationship to the companion host controllers. For example, the PORSTC registers should not be reset to their default values and the CF bit setting should not go to zero (retaining port ownership relationships).</p> <p>A host software read of this bit as zero indicates the Light Host Controller Reset has completed and it is safe for software to re-initialize the host controller. A host software read of this bit as a one indicates the Light Host</p> |
| 6              | R/W        | 0x0         | Interrupt on Async Advance Doorbell                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

| Offset: 0x0010 |                                                                    |             | Register Name: E_USBCMD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |           |         |   |                                           |   |                                                                    |
|----------------|--------------------------------------------------------------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|---------|---|-------------------------------------------|---|--------------------------------------------------------------------|
| Bit            | Read/Write                                                         | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |           |         |   |                                           |   |                                                                    |
|                |                                                                    |             | <p>This bit is used as a doorbell by software to tell the host controller to issue an interrupt the next time it advances asynchronous schedule. Software must write a 1 to this bit to ring the doorbell.</p> <p>When the host controller has evicted all appropriate cached schedule state, it sets the Interrupt on Async Advance status bit in the USBSTS. if the Interrupt on Async Advance Enable bit in the USBINTR register is a one then the host controller will assert an interrupt at the next interrupt threshold.</p> <p>The host controller sets this bit to a zero after it has set the Interrupt on Async Advance status bit in the USBSTS register to a one.</p> <p>Software should not write a one to this bit when the asynchronous schedule is disabled. Doing so will yield undefined results.</p> |           |         |   |                                           |   |                                                                    |
| 5              | R/W                                                                | 0x0         | <p>Asynchronous Schedule Enable</p> <p>This bit controls whether the host controller skips processing the Asynchronous Schedule. Values mean:</p> <table border="1"> <thead> <tr> <th>Bit Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Do not process the Asynchronous Schedule.</td></tr> <tr> <td>1</td><td>Use the ASYNLISTADDR register to access the Asynchronous Schedule.</td></tr> </tbody> </table> <p>The default value of this field is '0b'.</p>                                                                                                                                                                                                                                                                                                                                      | Bit Value | Meaning | 0 | Do not process the Asynchronous Schedule. | 1 | Use the ASYNLISTADDR register to access the Asynchronous Schedule. |
| Bit Value      | Meaning                                                            |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |           |         |   |                                           |   |                                                                    |
| 0              | Do not process the Asynchronous Schedule.                          |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |           |         |   |                                           |   |                                                                    |
| 1              | Use the ASYNLISTADDR register to access the Asynchronous Schedule. |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |           |         |   |                                           |   |                                                                    |
| 4              | R/W                                                                | 0x0         | <p>Periodic Schedule Enable</p> <p>This bit controls whether the host controller skips processing the Periodic Schedule. Values mean:</p> <table border="1"> <thead> <tr> <th>Bit Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Do not process the Periodic Schedule.</td></tr> <tr> <td>1</td><td>Use the PERIODICLISTBASE register to access the Periodic Schedule.</td></tr> </tbody> </table> <p>The default value of this field is '0b'.</p>                                                                                                                                                                                                                                                                                                                                                  | Bit Value | Meaning | 0 | Do not process the Periodic Schedule.     | 1 | Use the PERIODICLISTBASE register to access the Periodic Schedule. |
| Bit Value      | Meaning                                                            |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |           |         |   |                                           |   |                                                                    |
| 0              | Do not process the Periodic Schedule.                              |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |           |         |   |                                           |   |                                                                    |
| 1              | Use the PERIODICLISTBASE register to access the Periodic Schedule. |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |           |         |   |                                           |   |                                                                    |
| 3:2            | R/W                                                                | 0x0         | <p>Frame List Size</p> <p>This field is R/W only if Programmable Frame List Flag in the HCCPARAMS registers is set to a one. This field specifies the size of the Frame list. The size the frame list controls which bits</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |           |         |   |                                           |   |                                                                    |

| Offset: 0x0010 |                                                           |             | Register Name: E_USBCMD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |      |         |     |                                       |     |                         |     |                                                           |     |          |
|----------------|-----------------------------------------------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|---------|-----|---------------------------------------|-----|-------------------------|-----|-----------------------------------------------------------|-----|----------|
| Bit            | Read/Write                                                | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |      |         |     |                                       |     |                         |     |                                                           |     |          |
|                |                                                           |             | <p>in the Frame Index<br/>Register should be used for the Frame List Current index. Values mean:</p> <table border="1"> <tr> <th>Bits</th><th>Meaning</th></tr> <tr> <td>00b</td><td>1024 elements(4096bytes)Default value</td></tr> <tr> <td>01b</td><td>512 elements(2048bytes)</td></tr> <tr> <td>10b</td><td>256 elements(1024bytes)For resource-constrained condition</td></tr> <tr> <td>11b</td><td>reserved</td></tr> </table> <p>The default value is '00b'.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Bits | Meaning | 00b | 1024 elements(4096bytes)Default value | 01b | 512 elements(2048bytes) | 10b | 256 elements(1024bytes)For resource-constrained condition | 11b | reserved |
| Bits           | Meaning                                                   |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |      |         |     |                                       |     |                         |     |                                                           |     |          |
| 00b            | 1024 elements(4096bytes)Default value                     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |      |         |     |                                       |     |                         |     |                                                           |     |          |
| 01b            | 512 elements(2048bytes)                                   |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |      |         |     |                                       |     |                         |     |                                                           |     |          |
| 10b            | 256 elements(1024bytes)For resource-constrained condition |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |      |         |     |                                       |     |                         |     |                                                           |     |          |
| 11b            | reserved                                                  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |      |         |     |                                       |     |                         |     |                                                           |     |          |
| 1              | R/W                                                       | 0x0         | <p>Host Controller Reset<br/>This control bit is used by software to reset the host controller. The effects of this on Root Hub registers are similar to a Chip Hardware Reset.<br/>When software writes a one to this bit, the Host Controller resets its internal pipelines, timers, counters, state machines, etc. to their initial value. Any transaction currently in progress on USB is immediately terminated. A USB reset is not driven on downstream ports.<br/>All operational registers, including port registers and port state machines are set to their initial values. Port ownership reverts to the companion host controller(s). Software must reinitialize the host controller as described in Section 4.1 of the CHEI Specification in order to return the host controller to an operational state.<br/>This bit is set to zero by the Host Controller when the reset process is complete. Software cannot terminate the reset process early by writing a zero to this register.<br/>Software should not set this bit to a one when the HC Halted bit in the USBSTS register is a zero. Attempting to reset an actively running host controller will result in undefined behavior.</p> |      |         |     |                                       |     |                         |     |                                                           |     |          |
| 0              | R/W                                                       | 0x0         | <p>Run/Stop<br/>When set to a 1, the Host Controller proceeds with execution of the schedule. When set to 0, the Host Controller completes the current and any actively pipelined transactions on the USB and then halts. The Host Controller must halt within 16 micro-frames after</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |      |         |     |                                       |     |                         |     |                                                           |     |          |

| Offset: 0x0010 |            |             | Register Name: E_USBCMD                                                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                          |
|                |            |             | <p>software clears this bit.</p> <p>The HC Halted bit indicates when the Host Controller has finished its pending pipelined transactions and has entered the stopped state.</p> <p>Software must not write a one to this field unless the Host Controller is in the Halt State.</p> <p>The default value is 0x0.</p> |

#### 8.9.5.7 0x0014 EHCI USB Status Register (Default Value:0x0000\_1000)

| Offset: 0x0014 |            |             | Register Name: E_USBSTS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 31:16          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 15             | R          | 0x0         | <p>Asynchronous Schedule Status</p> <p>The bit reports the current real status of Asynchronous Schedule. If this bit is a zero then the status of the Asynchronous Schedule is disabled. If this bit is a one then the status of the Asynchronous Schedule is enabled. The Host Controller is not required to immediately disable or enable the Asynchronous Schedule when software transitions the Asynchronous Schedule Enable bit in the USBCMD register. When this bit and the Asynchronous Schedule Enable bit are the same value, the Asynchronous Schedule is either enabled (1) or disabled (0).</p> |
| 14             | R          | 0x0         | <p>Periodic Schedule Status</p> <p>The bit reports the current real status of the Periodic Schedule. If this bit is a zero then the status of the Periodic Schedule is disabled. If this bit is a one then the status of the Periodic Schedule is enabled. The Host Controller is not required to <i>immediately</i> disable or enable the Periodic Schedule when software transitions the <i>Periodic Schedule Enable</i> bit in the USBCMD register. When this bit and the <i>Periodic Schedule Enable</i> bit are the same value, the Periodic Schedule is either enabled (1) or disabled (0).</p>        |
| 13             | R          | 0x0         | <p>Reclamation</p> <p>This is a read-only status bit, which is used to detect an empty asynchronous schedule.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 12             | R          | 0x1         | <p>HC Halted</p> <p>This bit is a zero whenever the Run/Stop bit is a one.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

| Offset: 0x0014 |            |             | Register Name: E_USBSTS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                |            |             | The Host Controller Sets this bit to one after it has stopped executing as a result of the Run/Stop bit being set to 0, either by software or by the Host Controller Hardware (e.g. internal error).<br>The default value is '1'.                                                                                                                                                                                                                                                                           |
| 11:6           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 5              | R/WC       | 0x0         | Interrupt on Async Advance<br>System software can force the host controller to issue an interrupt the next time the host controller advances the asynchronous schedule by writing a one to the Interrupt on Async Advance Doorbell bit in the USBCMD register. This status bit indicates the assertion of that interrupt source.                                                                                                                                                                            |
| 4              | R/WC       | 0x0         | Host System Error<br>The Host Controller set this bit to 1 when a serious error occurs during a host system access involving the Host Controller module. When this error occurs, the Host Controller clears the Run/Stop bit in the Command register to prevent further execution of the scheduled TDs.                                                                                                                                                                                                     |
| 3              | R/WC       | 0x0         | Frame List Rollover<br>The Host Controller sets this bit to a one when the Frame List Index rolls over from its maximum value to zero. The exact value at which the rollover occurs depends on the frame list size. For example, if the frame list size is 1024, the Frame Index Register rolls over every time FRINDEX [13] toggles. Similarly, if the size is 512, the Host Controller sets this bit to a one every time FRINDEX [12] toggles.                                                            |
| 2              | R/WC       | 0x0         | Port Change Detect<br>The Host Controller sets this bit to a one when any port for which the Port Owner bit is set to zero has a change bit transition from a zero to a one or a Force Port Resume bit transition from a zero to a one as a result of a J-K transition detected on a suspended port. This bit will also be set as a result of the Connect Status Chang being set to a one after system software has relinquished ownership of a connected port by writing a one to a port's Port Owner bit. |
| 1              | R/WC       | 0x0         | USB Error Interrupt(USBERRINT)<br>The Host Controller sets this bit to 1 when completion                                                                                                                                                                                                                                                                                                                                                                                                                    |

| Offset: 0x0014 |            |             | Register Name: E_USBSTS                                                                                                                                                                                                                                                                                                                                    |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                |
|                |            |             | of USB transaction results in an error condition(e.g. error counter underflow).If the TD on which the error interrupt occurred also had its IOC bit set, both. This bit and USBINT bit are set.                                                                                                                                                            |
| 0              | R/WC       | 0x0         | USB Interrupt(USBINT)<br>The Host Controller sets this bit to a one on the completion of a USB transaction, which results in the retirement of a Transfer Descriptor that had its IOC bit set.<br>The Host Controller also sets this bit to 1 when a short packet is detected (actual number of bytes received was less than the expected number of bytes) |

#### 8.9.5.8 0x0018 EHCI USB Interrupt Enable Register (Default Value:0x0000\_0000)

| Offset: 0x0018 |            |             | Register Name: E_USBINTR                                                                                                                                                                                                                                                                         |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                      |
| 31:6           | /          | /           | /                                                                                                                                                                                                                                                                                                |
| 5              | R/W        | 0x0         | Interrupt on Async Advance Enable<br>When this bit is 1, and the Interrupt on Async Advance bit in the USBSTS register is 1, the host controller will issue an interrupt at the next interrupt threshold. The interrupt is acknowledged by software clearing the Interrupt on Async Advance bit. |
| 4              | R/W        | 0x0         | Host System Error Enable<br>When this bit is 1, and the Host System Error Status bit in the USBSTS register is 1, the host controller will issue an interrupt. The interrupt is acknowledged by software clearing the Host System Error bit.                                                     |
| 3              | R/W        | 0x0         | Frame List Rollover Enable<br>When this bit is 1, and the Frame List Rollover bit in the USBSTS register is 1, the host controller will issue an interrupt. The interrupt is acknowledged by software clearing the Frame List Rollover bit.                                                      |
| 2              | R/W        | 0x0         | Port Change Interrupt Enable<br>When this bit is 1, and the Port Chang Detect bit in the USBSTS register is 1, the host controller will issue an interrupt. The interrupt is acknowledged by software clearing the Port Chang Detect bit.                                                        |
| 1              | R/W        | 0x0         | USB Error Interrupt Enable<br>When this bit is 1, and the USBERRINT bit in the                                                                                                                                                                                                                   |

| Offset: 0x0018 |            |             | Register Name: E_USBINTR                                                                                                                                                                                                                      |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                   |
|                |            |             | USBSTS register is 1, the host controller will issue an interrupt at the next interrupt threshold.<br>The interrupt is acknowledged by software clearing the USBERRINT bit.                                                                   |
| 0              | R/W        | 0x0         | USB Interrupt Enable<br>When this bit is 1, and the USBINT bit in the USBSTS register is 1, the host controller will issue an interrupt at the next interrupt threshold.<br>The interrupt is acknowledged by software clearing the USBINT bit |

#### 8.9.5.9 0x001C EHCI Frame Index Register (Default Value:0x0000\_0000)

| Offset: 0x001C          |                 |             | Register Name: E_FRINDEX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                         |                 |   |     |      |    |     |     |    |     |     |    |     |          |  |
|-------------------------|-----------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|-----------------|---|-----|------|----|-----|-----|----|-----|-----|----|-----|----------|--|
| Bit                     | Read/Write      | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                         |                 |   |     |      |    |     |     |    |     |     |    |     |          |  |
| 31:14                   | /               | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                         |                 |   |     |      |    |     |     |    |     |     |    |     |          |  |
| 13:0                    | R/W             | 0           | Frame Index<br>The value in this register increments at the end of each time frame (e.g. micro-frame). Bits[N:3] are used for the Frame List current index. It means that each location of the frame list is accessed 8 times (frames or Micro-frames) before moving to the next index. The following illustrates values of N based on the value of the Frame List Size field in the USBCMD register. <table border="1" data-bbox="743 1372 1367 1626"> <tr> <th>USBCMD[Frame List Size]</th> <th>Number Elements</th> <th>N</th> </tr> <tr> <td>00b</td> <td>1024</td> <td>12</td> </tr> <tr> <td>01b</td> <td>512</td> <td>11</td> </tr> <tr> <td>10b</td> <td>256</td> <td>10</td> </tr> <tr> <td>11b</td> <td>Reserved</td> <td></td> </tr> </table> | USBCMD[Frame List Size] | Number Elements | N | 00b | 1024 | 12 | 01b | 512 | 11 | 10b | 256 | 10 | 11b | Reserved |  |
| USBCMD[Frame List Size] | Number Elements | N           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                         |                 |   |     |      |    |     |     |    |     |     |    |     |          |  |
| 00b                     | 1024            | 12          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                         |                 |   |     |      |    |     |     |    |     |     |    |     |          |  |
| 01b                     | 512             | 11          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                         |                 |   |     |      |    |     |     |    |     |     |    |     |          |  |
| 10b                     | 256             | 10          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                         |                 |   |     |      |    |     |     |    |     |     |    |     |          |  |
| 11b                     | Reserved        |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                         |                 |   |     |      |    |     |     |    |     |     |    |     |          |  |



#### NOTE

This register must be written as a DWord. Byte writes produce undefined results.

#### 8.9.5.10 0x0024 EHCI Periodic Frame List Base Address Register (Default Value:0x0000\_0000)

| Offset: 0x0024 |            |             | Register Name: E_PERIODICLISTBASE |
|----------------|------------|-------------|-----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                       |

| Offset: 0x0024 |            |             | Register Name: E_PERIODICLISTBASE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 31:12          | R/W        | 0x0         | <p>Base Address<br/>These bits correspond to memory address signals [31:12], respectively.</p> <p>This register contains the beginning address of the Periodic Frame List in the system memory.</p> <p>System software loads this register prior to starting the schedule execution by the Host Controller. The memory structure referenced by this physical memory pointer is assumed to be 4 Kbyte aligned. The contents of this register are combined with the Frame Index Register (FRINDEX) to enable the Host Controller to step through the Periodic Frame List in sequence.</p> |
| 11:0           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |



#### NOTE

Writes must be Dword Writes.

#### 8.9.5.11 0x0028 EHCI Current Asynchronous List Address Register (Default Value:0x0000\_0000)

| Offset: 0x0028 |            |             | Register Name: E_ASYNCLISTADDR                                                                                                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                   |
| 31:5           | R/W        | 0x0         | <p>Link Pointer (LP)<br/>This field contains the address of the next asynchronous queue head to be executed.</p> <p>These bits correspond to memory address signals [31:5], respectively.</p> |
| 4:0            | /          | /           | /                                                                                                                                                                                             |



#### NOTE

Write must be DWord Writes.

#### 8.9.5.12 0x0050 EHCI Configure Flag Register (Default Value:0x0000\_0000)

| Offset: 0x0050 |            |             | Register Name: E_CONFIGFLAG |
|----------------|------------|-------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                 |
| 31:1           | /          | /           | /                           |

| Offset: 0x0050 |                                                                                                            |             | Register Name: E_CONFIGFLAG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |           |         |   |                                                                                                            |   |                                                                             |
|----------------|------------------------------------------------------------------------------------------------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|---------|---|------------------------------------------------------------------------------------------------------------|---|-----------------------------------------------------------------------------|
| Bit            | Read/Write                                                                                                 | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |           |         |   |                                                                                                            |   |                                                                             |
| 0              | R/W                                                                                                        | 0x0         | <p>Configure Flag (CF)<br/>Host software sets this bit as the last action in its process of configuring the Host Controller. This bit controls the default port-routing control logic as follow:</p> <table border="1"> <thead> <tr> <th>Val<br/>ue</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0</td><td>Port routing control logic default-routs each port to an implementation dependent classic host controller.</td></tr> <tr> <td>1</td><td>Port routing control logic default-routs all ports to this host controller.</td></tr> </tbody> </table> <p>The default value of this field is '0'.</p> | Val<br>ue | Meaning | 0 | Port routing control logic default-routs each port to an implementation dependent classic host controller. | 1 | Port routing control logic default-routs all ports to this host controller. |
| Val<br>ue      | Meaning                                                                                                    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |           |         |   |                                                                                                            |   |                                                                             |
| 0              | Port routing control logic default-routs each port to an implementation dependent classic host controller. |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |           |         |   |                                                                                                            |   |                                                                             |
| 1              | Port routing control logic default-routs all ports to this host controller.                                |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |           |         |   |                                                                                                            |   |                                                                             |



#### NOTE

This register is not used in the normal implementation.

#### 8.9.5.13 0x0054 EHCI Port Status and Control Register (Default Value:0x0000\_2000)

| Offset: 0x0054 |                                           |             | Register Name: E_PORTSC                                                                                                                                                                                                                                                                                                         |      |           |       |                                           |
|----------------|-------------------------------------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|-------|-------------------------------------------|
| Bit            | Read/Write                                | Default/Hex | Description                                                                                                                                                                                                                                                                                                                     |      |           |       |                                           |
| 31:22          | /                                         | /           | /                                                                                                                                                                                                                                                                                                                               |      |           |       |                                           |
| 21             | R/W                                       | 0x0         | <p>Wake on Disconnect Enable (WKDSCNNT_E)<br/>Writing this bit to a one enables the port to be sensitive to device disconnects as wake-up events.<br/>This field is zero if Port Power is zero.<br/>The default value in this field is '0'.</p>                                                                                 |      |           |       |                                           |
| 20             | R/W                                       | 0x0         | <p>Wake on Connect Enable (WKCNNT_E)<br/>Writing this bit to a one enable the port to be sensitive to device connects as wake-up events.<br/>This field is zero if Port Power is zero.<br/>The default value in this field is '0'.</p>                                                                                          |      |           |       |                                           |
| 19:16          | R/W                                       | 0x0         | <p>Port Test Control<br/>The value in this field specifies the test mode of the port. The encoding of the test mode bits are as follows:</p> <table border="1"> <thead> <tr> <th>Bits</th><th>Test Mode</th></tr> </thead> <tbody> <tr> <td>0000b</td><td>The port is NOT operating in a test mode.</td></tr> </tbody> </table> | Bits | Test Mode | 0000b | The port is NOT operating in a test mode. |
| Bits           | Test Mode                                 |             |                                                                                                                                                                                                                                                                                                                                 |      |           |       |                                           |
| 0000b          | The port is NOT operating in a test mode. |             |                                                                                                                                                                                                                                                                                                                                 |      |           |       |                                           |

| Offset: 0x0054 |                   |                                              | Register Name: E_PORTSC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |            |              |                |              |       |                                           |       |             |                                           |                   |         |                                              |       |           |                                           |
|----------------|-------------------|----------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|--------------|----------------|--------------|-------|-------------------------------------------|-------|-------------|-------------------------------------------|-------------------|---------|----------------------------------------------|-------|-----------|-------------------------------------------|
| Bit            | Read/Write        | Default/Hex                                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |            |              |                |              |       |                                           |       |             |                                           |                   |         |                                              |       |           |                                           |
|                |                   |                                              | <table border="1"> <tr><td>0001b</td><td>Test J_STATE</td></tr> <tr><td>0010b</td><td>Test K_STATE</td></tr> <tr><td>0011b</td><td>Test SE0_NAK</td></tr> <tr><td>0100b</td><td>Test Packet</td></tr> <tr><td>0101b</td><td>Test FORCE_ENABLE</td></tr> <tr><td>0110b-</td><td>Reserved</td></tr> <tr><td>1111b</td><td></td></tr> </table> <p>The default value in this field is '0000b'.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0001b      | Test J_STATE | 0010b          | Test K_STATE | 0011b | Test SE0_NAK                              | 0100b | Test Packet | 0101b                                     | Test FORCE_ENABLE | 0110b-  | Reserved                                     | 1111b |           |                                           |
| 0001b          | Test J_STATE      |                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |            |              |                |              |       |                                           |       |             |                                           |                   |         |                                              |       |           |                                           |
| 0010b          | Test K_STATE      |                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |            |              |                |              |       |                                           |       |             |                                           |                   |         |                                              |       |           |                                           |
| 0011b          | Test SE0_NAK      |                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |            |              |                |              |       |                                           |       |             |                                           |                   |         |                                              |       |           |                                           |
| 0100b          | Test Packet       |                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |            |              |                |              |       |                                           |       |             |                                           |                   |         |                                              |       |           |                                           |
| 0101b          | Test FORCE_ENABLE |                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |            |              |                |              |       |                                           |       |             |                                           |                   |         |                                              |       |           |                                           |
| 0110b-         | Reserved          |                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |            |              |                |              |       |                                           |       |             |                                           |                   |         |                                              |       |           |                                           |
| 1111b          |                   |                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |            |              |                |              |       |                                           |       |             |                                           |                   |         |                                              |       |           |                                           |
| 15:14          | /                 | /                                            | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |            |              |                |              |       |                                           |       |             |                                           |                   |         |                                              |       |           |                                           |
| 13             | R/W               | 0x1                                          | <p>Port Owner</p> <p>This bit unconditionally goes to a 0b when the Configured bit in the CONFIGFLAG register makes a 0b to 1b transition. This bit unconditionally goes to 1b whenever the Configured bit is zero.</p> <p>System software uses this field to release ownership of the port to selected host controller (in the event that the attached device is not a high-speed device). Software writes a one to this bit when the attached device is not a high-speed device. A one in this bit means that a companion host controller owns and controls the port.</p> <p>Default Value = 1b.</p>                                                                                                                                                                                                                                                                                          |            |              |                |              |       |                                           |       |             |                                           |                   |         |                                              |       |           |                                           |
| 12             | /                 | /                                            | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |            |              |                |              |       |                                           |       |             |                                           |                   |         |                                              |       |           |                                           |
| 11:10          | R                 | 0x0                                          | <p>Line Status</p> <p>These bits reflect the current logical levels of the D+ (bit11) and D-(bit10) signal lines. These bits are used for detection of low-speed USB devices prior to port reset and enable sequence. This read only field is valid only when the port enable bit is zero and the current connect status bit is set to a one.</p> <p>The encoding of the bits are:</p> <table border="1"> <thead> <tr> <th>Bit[11:10]</th> <th>USB State</th> <th>Interpretation</th> </tr> </thead> <tbody> <tr><td>00b</td><td>SE0</td><td>Not Low-speed device, perform EHCI reset.</td></tr> <tr><td>10b</td><td>J-state</td><td>Not Low-speed device, perform EHCI reset.</td></tr> <tr><td>01b</td><td>K-state</td><td>Low-speed device, release ownership of port.</td></tr> <tr><td>11b</td><td>Undefined</td><td>Not Low-speed device, perform EHCI reset.</td></tr> </tbody> </table> | Bit[11:10] | USB State    | Interpretation | 00b          | SE0   | Not Low-speed device, perform EHCI reset. | 10b   | J-state     | Not Low-speed device, perform EHCI reset. | 01b               | K-state | Low-speed device, release ownership of port. | 11b   | Undefined | Not Low-speed device, perform EHCI reset. |
| Bit[11:10]     | USB State         | Interpretation                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |            |              |                |              |       |                                           |       |             |                                           |                   |         |                                              |       |           |                                           |
| 00b            | SE0               | Not Low-speed device, perform EHCI reset.    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |            |              |                |              |       |                                           |       |             |                                           |                   |         |                                              |       |           |                                           |
| 10b            | J-state           | Not Low-speed device, perform EHCI reset.    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |            |              |                |              |       |                                           |       |             |                                           |                   |         |                                              |       |           |                                           |
| 01b            | K-state           | Low-speed device, release ownership of port. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |            |              |                |              |       |                                           |       |             |                                           |                   |         |                                              |       |           |                                           |
| 11b            | Undefined         | Not Low-speed device, perform EHCI reset.    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |            |              |                |              |       |                                           |       |             |                                           |                   |         |                                              |       |           |                                           |

| Offset: 0x0054              |            |             | Register Name: E_PORTSC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                             |            |    |         |    |        |
|-----------------------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|------------|----|---------|----|--------|
| Bit                         | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                             |            |    |         |    |        |
|                             |            |             | This value of this field is undefined if Port Power is zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                             |            |    |         |    |        |
| 9                           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                             |            |    |         |    |        |
| 8                           | R/W        | 0x0         | <p>Port Reset<br/>1=Port is in Reset. 0=Port is not in Reset. Default value = 0.<br/>When software writes a one to this bit (from a zero), the bus reset sequence as defined in the USB Specification Revision 2.0 is started. Software writes a zero to this bit to terminate the bus reset sequence. Software must keep this bit at a one long enough to ensure the reset sequence, as specified in the USB Specification Revision 2.0, completes.<br/>Note: When software writes this bit to a one , it must also write a zero to the Port Enable bit.</p> <p>Note that when software writes a zero to this bit there may be a delay before the bit status changes to a zero. The bit status will not read as a zero until after the reset has completed. If the port is in high-speed mode after reset is complete, the host controller will automatically enable this port (e.g. set the Port Enable bit to a one). A host controller must terminate the reset and stabilize the state of the port within 2 milliseconds of software transitioning this bit from a one to a zero. For example: if the port detects that the attached device is high-speed during reset, then the host controller must have the port in the enabled state with 2ms of software writing this bit to a zero. The HC Halted bit in the USBSTS register should be a zero before software attempts to use this bit. The host controller may hold Port Reset asserted to a one when the HC Halted bit is a one.<br/>This field is zero if Port Power is zero.</p> |                             |            |    |         |    |        |
| 7                           | R/W        | 0x0         | <p>Suspend<br/>Port Enabled Bit and Suspend bit of this register define the port states as follows:</p> <table border="1"> <tr> <th>Bits[Port Enables, Suspend]</th><th>Port State</th></tr> <tr> <td>0x</td><td>Disable</td></tr> <tr> <td>10</td><td>Enable</td></tr> </table>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Bits[Port Enables, Suspend] | Port State | 0x | Disable | 10 | Enable |
| Bits[Port Enables, Suspend] | Port State |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                             |            |    |         |    |        |
| 0x                          | Disable    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                             |            |    |         |    |        |
| 10                          | Enable     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                             |            |    |         |    |        |

| Offset: 0x0054 |            |             | Register Name: E_PORTSC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |    |         |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |    |         |
|                |            |             | <table border="1" style="margin-left: auto; margin-right: auto;"> <tr> <td style="width: 50px;">11</td><td>Suspend</td></tr> </table> <p>When in suspend state, downstream propagation of data is blocked on this port, except for port reset. The blocking occurs at the end of the current transaction, if a transaction was in progress when this bit was written to 1. In the suspend state, the port is sensitive to resume detection. Note that the bit status does not change until the port is suspend and that there may be a delay in suspending a port if there is a transaction currently in progress on the USB.</p> <p>A write of zero to this bit is ignored by the host controller. The host controller will unconditionally set this bit to a zero when:</p> <ul style="list-style-type: none"> <li>① Software sets the Force Port Resume bit to a zero(from a one).</li> <li>② Software sets the Port Reset bit to a one(from a zero).</li> </ul> <p>If host software sets this bit to a one when the port is not enabled(i.e. Port enabled bit is a zero), the results are undefined.</p> <p>This field is zero if Port Power is zero.</p> <p>The default value in this field is '0'.</p> | 11 | Suspend |
| 11             | Suspend    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |    |         |
| 6              | R/W        | 0x0         | <p>Force Port Resume</p> <p>1 = Resume detected/driven on port. 0 = No resume (K-state) detected/driven on port. Default value = 0.</p> <p>This functionality defined for manipulating this bit depends on the value of the Suspend bit. For example, if the port is not suspend and software transitions this bit to a one, then the effects on the bus are undefined. Software sets this bit to 1 to drive resume signaling. The Host Controller sets this bit to a 1 if a J-to-K transition is detected while the port is in the Suspend state. When this bit transitions to a one because a J-to-K transition is detected, the Port Change Detect bit in the USBSTS register is also set to a one. If software sets this bit to a one, the host controller must not set the Port Change Detect bit.</p> <p>Note that when the EHCI controller owns the port, the resume sequence follows the defined sequence documented in the USB Specification Revision 2.0.</p> <p>The resume signaling (Full-speed 'K') is driven on the</p>                                                                                                                                                                        |    |         |

| Offset: 0x0054 |            |             | Register Name: E_PORTSC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                |            |             | port as long as this remains a one. Software must appropriately time the Resume and set this bit to a zero when the appropriate amount of time has elapsed. Writing a zero (from one) causes the port to return high-speed mode (forcing the bus below the port into a high-speed idle). This bit will remain a one until the port has switched to high-speed idle. The host controller must complete this transition within 2 milliseconds of software setting this bit to a zero. This field is zero if Port Power is zero. |
| 5              | R/WC       | 0x0         | Over-current Change<br>This bit gets set to a one when there is a change to Over-current Active. Software clears this bit by writing a one to this bit position.                                                                                                                                                                                                                                                                                                                                                              |
| 4              | R          | 0x0         | Over-current Active<br>0 = This port does not have an over-current condition<br>1 = This port currently has an over-current condition<br>This bit will automatically transition from a one to a zero when the over current condition is removed.<br>The default value of this bit is '0'.                                                                                                                                                                                                                                     |
| 3              | R/WC       | 0x0         | Port Enable/Disable Change<br>1 = Port enabled/disabled status has changed<br>0 = No change<br>For the root hub, this bit gets set to a one only when a port is disabled due to the appropriate conditions existing at the EOF2 point (See Chapter 11 of the USB Specification for the definition of a Port Error).<br>Software clears this bit by writing a 1 to it.<br>This field is zero if Port Power is zero.                                                                                                            |
| 2              | R/W        | 0x0         | Port Enabled/Disabled<br>1=Enable<br>0=Disable<br>Ports can only be enabled by the host controller as a part of the reset and enable. Software cannot enable a port by writing a one to this field. The host controller will only set this bit to a one when the reset sequence determines that the attached device is a high-speed device.<br>Ports can be disabled by either a fault condition (Disconnect event or other fault condition) or by host software. Note that the bit status does not change                    |

| Offset: 0x0054 |            |             | Register Name: E_PORTSC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                |            |             | <p>until the port state actually changes. There may be a delay in disabling or enabling a port due to other host controller and bus events.</p> <p>When the port is disabled, downstream propagation of data is blocked on this port except for reset.</p> <p>The default value of this field is '0'.</p> <p>This field is zero if Port Power is zero.</p>                                                                                                                                                                                                                                            |
| 1              | R/WC       | 0x0         | <p>Connect Status Change<br/>1=Change in Current Connect Status<br/>0=No change</p> <p>Indicates a change has occurred in the current connect status of the port. The host controller sets this bit for all changes to the port device connect status, even if system software has not cleared an existing connect status change. For example, the insertion status changes twice before system software has cleared the changed condition, hub hardware will be "setting" an already-set bit. Software sets this bit to 0 by writing a 1 to it.</p> <p>This field is zero if Port Power is zero.</p> |
| 0              | R          | 0x0         | <p>Current Connect Status</p> <p>Device is present on port when the value of this field is a one, and no device is present on port when the value of this field is a zero. This value reflects the current state of the port, and may not correspond directly to the event that caused the Connect Status Change(Bit 1) to be set.</p> <p>This field is zero if Port Power zero.</p>                                                                                                                                                                                                                  |



#### NOTE

This register is only reset by hardware or in response to a host controller reset.

### 8.9.6 OHCI Register Description

#### 8.9.6.1 0x0404 OHCI Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0404 |            |    | Register Name: O_HcRevision |
|----------------|------------|----|-----------------------------|
| Bit            | Read/Write |    | Description                 |
|                | HCD        | HC |                             |

| Offset: 0x0404 |                |     |             | Register Name: O_HcRevision                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |          |     |           |     |                |     |            |
|----------------|----------------|-----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|----------|-----|-----------|-----|----------------|-----|------------|
| Bit            | Read/Write     |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |     |          |     |           |     |                |     |            |
|                | HCD            | HC  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |          |     |           |     |                |     |            |
| 31:11          | /              | /   | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |     |          |     |           |     |                |     |            |
| 10             | R/W            | R   | 0x0         | <p>RemoteWakeUpEnable</p> <p>This bit is used by HCD to enable or disable the remote wakeup feature upon the detection of upstream resume signaling. When this bit is set and the ResumeDetected bit in <i>HcInterruptStatus</i> is set, a remote wakeup is signaled to the host system. Setting this bit has no impact on the generation of hardware interrupt.</p>                                                                                                                                                                                                                                                |     |          |     |           |     |                |     |            |
| 9              | R/W            | R/W | 0x0         | <p>RemoteWakeUpConnected</p> <p>This bit indicates whether HC supports remote wakeup signaling. If remote wakeup is supported and used by the system, it is the responsibility of system firmware to set this bit during POST. HC clear the bit upon a hardware reset but does not alter it upon a software reset. Remote wakeup signaling of the host system is host-bus-specific and is not described in this specification.</p>                                                                                                                                                                                  |     |          |     |           |     |                |     |            |
| 8              | R/W            | R   | 0x0         | <p>InterruptRouting</p> <p>This bit determines the routing of interrupts generated by events registered in <i>HcInterruptStatus</i>. If clear, all interrupt are routed to the normal host bus interrupt mechanism. If set interrupts are routed to the System Management Interrupt. HCD clears this bit upon a hardware reset, but it does not alter this bit upon a software reset. HCD uses this bit as a tag to indicate the ownership of HC.</p>                                                                                                                                                               |     |          |     |           |     |                |     |            |
| 7:6            | R/W            | R/W | 0x0         | <p>HostControllerFunctionalState for USB</p> <table border="1"> <tr> <td>00b</td><td>USBReset</td></tr> <tr> <td>01b</td><td>USBResume</td></tr> <tr> <td>10b</td><td>USBOperational</td></tr> <tr> <td>11b</td><td>USBSuspend</td></tr> </table> <p>A transition to USBOperational from another state causes SOF generation to begin 1 ms later. HCD may determine whether HC has begun sending SOFs by reading the StartFrame field of <i>HcInterruptStatus</i>.</p> <p>This field may be changed by HC only when in the USBSUSPEND state. HC may move from the USBSUSPEND state to the USBRESUME state after</p> | 00b | USBReset | 01b | USBResume | 10b | USBOperational | 11b | USBSuspend |
| 00b            | USBReset       |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |          |     |           |     |                |     |            |
| 01b            | USBResume      |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |          |     |           |     |                |     |            |
| 10b            | USBOperational |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |          |     |           |     |                |     |            |
| 11b            | USBSuspend     |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |     |          |     |           |     |                |     |            |

| Offset: 0x0404 |            |    |             | Register Name: O_HcRevision                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                | HCD        | HC |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                |            |    |             | detecting the resume signaling from a downstream port.<br>HC enters USBSUSPEND after a software reset, whereas it enters USBRESET after a hardware reset. The latter also resets the Root Hub and asserts subsequent reset signaling to downstream ports.                                                                                                                                                                                                                                                                   |
| 5              | R/W        | R  | 0x0         | BulkListEnable<br>This bit is set to enable the processing of the Bulk list in the next Frame. If cleared by HCD, the processing of the Bulk list does not occur after the next SOF. HC checks this bit whenever it determines to process the list. When disabled, HCD may modify the list. If <i>HcBulkCurrentED</i> is pointing to an ED to be removed, HCD must advance the pointer by updating <i>HcBulkCurrentED</i> before re-enabling processing of the list.                                                        |
| 4              | R/W        | R  | 0x0         | ControlListEnable<br>This bit is set to enable the processing of the Control list in the next Frame. If cleared by HCD, the processing of the Control list does not occur after the next SOF. HC must check this bit whenever it determines to process the list. When disabled, HCD may modify the list. If <i>HcControlCurrentED</i> is pointing to an ED to be removed, HCD must advance the pointer by updating <i>HcControlCurrentED</i> before re-enabling processing of the list.                                     |
| 3              | R/W        | R  | 0x0         | IsochronousEnable<br>This bit is used by HCD to enable/disable processing of isochronous EDs. While processing the periodic list in a Frame, HC checks the status of this bit when it finds an Isochronous ED (F=1). If set (enabled), HC continues processing the EDs. If cleared (disabled), HC halts processing of the periodic list (which now contains only isochronous EDs) and begins processing the Bulk/Control lists.<br>Setting this bit is guaranteed to take effect in the next Frame (not the current Frame). |
| 2              | R/W        | R  | 0x0         | PeriodicListEnable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

| Offset: 0x0404 |                                         |    |             | Register Name: O_HcRevision                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |      |                                         |   |     |   |     |   |     |   |     |
|----------------|-----------------------------------------|----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------------------------------------|---|-----|---|-----|---|-----|---|-----|
| Bit            | Read/Write                              |    | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |      |                                         |   |     |   |     |   |     |   |     |
|                | HCD                                     | HC |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |                                         |   |     |   |     |   |     |   |     |
|                |                                         |    |             | This bit is set to enable the processing of periodic list in the next Frame. If cleared by HCD, processing of the periodic list does not occur after the next SOF. HC must check this bit before it starts processing the list.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |                                         |   |     |   |     |   |     |   |     |
| 1:0            | R/W                                     | R  | 0x0         | <p>ControlBulkServiceRatio</p> <p>This specifies the service ratio between Control and Bulk EDs. Before processing any of the nonperiodic lists, HC must compare the ratio specified with its internal count on how many nonempty Control EDs have been processed, in determining whether to continue serving another Control ED or switching to Bulk EDs. The internal count will be retained when crossing the frame boundary. In case of reset, HCD is responsible for restoring this value.</p> <table border="1"> <thead> <tr> <th>CBSR</th> <th>No. of Control EDs Over Bulk EDs Served</th> </tr> </thead> <tbody> <tr> <td>0</td> <td>1:1</td> </tr> <tr> <td>1</td> <td>2:1</td> </tr> <tr> <td>2</td> <td>3:1</td> </tr> <tr> <td>3</td> <td>4:1</td> </tr> </tbody> </table> <p>The default value is 0x0.</p> | CBSR | No. of Control EDs Over Bulk EDs Served | 0 | 1:1 | 1 | 2:1 | 2 | 3:1 | 3 | 4:1 |
| CBSR           | No. of Control EDs Over Bulk EDs Served |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |                                         |   |     |   |     |   |     |   |     |
| 0              | 1:1                                     |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |                                         |   |     |   |     |   |     |   |     |
| 1              | 2:1                                     |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |                                         |   |     |   |     |   |     |   |     |
| 2              | 3:1                                     |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |                                         |   |     |   |     |   |     |   |     |
| 3              | 4:1                                     |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |                                         |   |     |   |     |   |     |   |     |

#### 8.9.6.2 0x0408 OHCI Command Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0408 |            |     |             | Register Name: O_HcCommandStatus                                                                                                                                                                                                                                                                                                                                                |
|----------------|------------|-----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                     |
|                | HCD        | HC  |             |                                                                                                                                                                                                                                                                                                                                                                                 |
| 31:18          | /          | /   | 0x0         | <b>Reserved</b>                                                                                                                                                                                                                                                                                                                                                                 |
| 17:16          | R          | R/W | 0x0         | <p><b>SchedulingOverrunCount</b></p> <p>These bits are incremented on each scheduling overrun error. It is initialized to 00b and wraps around at 11b. This will be incremented when a scheduling overrun is detected even if <b>SchedulingOverrun</b> in <b>HciInterruptStatus</b> has already been set. This is used by HCD to monitor any persistent scheduling problem.</p> |
| 15:4           | /          | /   | /           | /                                                                                                                                                                                                                                                                                                                                                                               |
| 3              | R/W        | R/W | 0x0         | <p><b>OwershipChangeRequest</b></p> <p>This bit is set by an OS HCD to request a change of</p>                                                                                                                                                                                                                                                                                  |

| Offset: 0x0408 |            |     |             | Register Name: O_HcCommandStatus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------|------------|-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                | HCD        | HC  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                |            |     |             | control of the HC. When set HC will set the <b>OwnershipChange</b> field in <i>HcInterruptStatus</i> . After the changeover, this bit is cleared and remains so until the next request from OS HCD.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 2              | R/W        | R/W | 0x0         | <p><b>BulkListFilled</b></p> <p>This bit is used to indicate whether there are any TDs on the Bulk list. It is set by HCD whenever it adds a TD to an ED in the Bulk list.</p> <p>When HC begins to process the head of the Bulk list, it checks BLF. As long as <b>BulkListFilled</b> is 0, HC will not start processing the Bulk list. If <b>BulkListFilled</b> is 1, HC will start processing the Bulk list and will set BF to 0. If HC finds a TD on the list, then HC will set <b>BulkListFilled</b> to 1 causing the Bulk list processing to continue. If no TD is found on the Bulk list, and if HCD does not set <b>BulkListFilled</b>, then <b>BulkListFilled</b> will still be 0 when HC completes processing the Bulk list and Bulk list processing will stop.</p>                                                  |
| 1              | R/W        | R/W | 0x0         | <p><b>ControlListFilled</b></p> <p>This bit is used to indicate whether there are any TDs on the Control list. It is set by HCD whenever it adds a TD to an ED in the Control list.</p> <p>When HC begins to process the head of the Control list, it checks CLF. As long as <b>ControlListFilled</b> is 0, HC will not start processing the Control list. If CF is 1, HC will start processing the Control list and will set <b>ControlListFilled</b> to 0. If HC finds a TD on the list, then HC will set <b>ControlListFilled</b> to 1 causing the Control list processing to continue. If no TD is found on the Control list, and if the HCD does not set <b>ControlListFilled</b>, then <b>ControlListFilled</b> will still be 0 when HC completes processing the Control list and Control list processing will stop.</p> |
| 0              | R/W        | R/E | 0x0         | <p><b>HostControllerReset</b></p> <p>This bit is by HCD to initiate a software reset of HC. Regardless of the functional state of HC, it moves to the USBsuspend state in which most of the operational registers are reset except those stated otherwise; e.g., the InterruptRouting field of HcControl, and no Host bus accesses are allowed. This bit is</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

| Offset: 0x0408 |            |    |             | Register Name: O_HcCommandStatus                                                                                                                                                                                                                         |
|----------------|------------|----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                                                                                                                                                                                                                                              |
|                | HCD        | HC |             |                                                                                                                                                                                                                                                          |
|                |            |    |             | cleared by HC upon the completion of the reset operation. The reset operation must be completed within 10 ms. This bit, when set, should not cause a reset to the Root Hub and no subsequent reset signaling should be asserted to its downstream ports. |

#### 8.9.6.3 0x040C OHCI Interrupt Status Register (Default Value: 0x0000\_0000)

| Offset: 0x040C |            |     |             | Register Name: O_HcInterruptStatus                                                                                                                                                                                                                                             |
|----------------|------------|-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |     | Default/Hex | Description                                                                                                                                                                                                                                                                    |
|                | HCD        | HC  |             |                                                                                                                                                                                                                                                                                |
| 31:7           | /          | /   | /           | /                                                                                                                                                                                                                                                                              |
| 6              | R/W        | R/W | 0x0         | <p><b>RootHubStatusChange</b><br/> This bit is set when the content of <i>HcRhStatus</i> or the content of any of <i>HcRhPortStatus[NumberofDownstreamPort]</i> has changed.</p>                                                                                               |
| 5              | R/W        | R/W | 0x0         | <p><b>FrameNumberOverflow</b><br/> This bit is set when the MSb of <i>HcFmNumber</i> (bit 15) changes value, from 0 to 1 or from 1 to 0, and after <i>HccaFrameNumber</i> has been updated.</p>                                                                                |
| 4              | R/W        | R/W | 0x0         | <p><b>UnrecoverableError</b><br/> This bit is set when HC detects a system error not related to USB. HC should not proceed with any processing nor signaling before the system error has been corrected. HCD clears this bit after HC has been reset.</p>                      |
| 3              | R/W        | R/W | 0x0         | <p><b>ResumeDetected</b><br/> This bit is set when HC detects that a device on the USB is asserting resume signaling. It is the transition from no resume signaling to resume signaling causing this bit to be set. This bit is not set when HCD sets the USBRseume state.</p> |
| 2              | R/W        | R/W | 0x0         | <p><b>StartofFrame</b><br/> This bit is set by HC at each start of frame and after the update of <i>HccaFrameNumber</i>. HC also generates a SOF token at the same time.</p>                                                                                                   |
| 1              | R/W        | R/W | 0x0         | <p><b>WritebackDoneHead</b><br/> This bit is set immediately after HC has written</p>                                                                                                                                                                                          |

| Offset: 0x040C |            |     |             | Register Name: O_HcInterruptStatus                                                                                                                                                                                                                                    |
|----------------|------------|-----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |     | Default/Hex | Description                                                                                                                                                                                                                                                           |
|                | HCD        | HC  |             |                                                                                                                                                                                                                                                                       |
|                |            |     |             | <i>HcDoneHead</i> to <i>HccaDoneHead</i> . Further updates of the <i>HccaDoneHead</i> will not occur until this bit has been cleared. HCD should only clear this bit after it has saved the content of <i>HccaDoneHead</i> .                                          |
| 0              | R/W        | R/W | 0x0         | <b>SchedulingOverrun</b><br>This bit is set when the USB schedule for the current Frame overruns and after the update of <i>HccaFrameNumber</i> . A scheduling overrun will also cause the <b>SchedulingOverrunCount</b> of <i>HcCommandStatus</i> to be incremented. |

#### 8.9.6.4 0x0410 OHCI Interrupt Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x0410 |                                                           |    |             | Register Name: O_HcInterruptEnable                                                                                                                                                                                                                 |   |        |   |                                                           |
|----------------|-----------------------------------------------------------|----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|--------|---|-----------------------------------------------------------|
| Bit            | Read/Write                                                |    | Default/Hex | Description                                                                                                                                                                                                                                        |   |        |   |                                                           |
|                | HCD                                                       | HC |             |                                                                                                                                                                                                                                                    |   |        |   |                                                           |
| 31             | R/W                                                       | R  | 0x0         | <b>MasterInterruptEnable</b><br>A '0' written to this field is ignored by HC. A '1' written to this field enables interrupt generation due to events specified in the other bits of this register. This is used by HCD as Master Interrupt Enable. |   |        |   |                                                           |
| 30:7           | /                                                         | /  | /           | /                                                                                                                                                                                                                                                  |   |        |   |                                                           |
| 6              | R/W                                                       | R  | 0x0         | <b>RootHubStatusChange Interrupt Enable</b> <table border="1"> <tr> <td>0</td><td>Ignore</td></tr> <tr> <td>1</td><td>Enable interrupt generation due to Root Hub Status Change</td></tr> </table>                                                 | 0 | Ignore | 1 | Enable interrupt generation due to Root Hub Status Change |
| 0              | Ignore                                                    |    |             |                                                                                                                                                                                                                                                    |   |        |   |                                                           |
| 1              | Enable interrupt generation due to Root Hub Status Change |    |             |                                                                                                                                                                                                                                                    |   |        |   |                                                           |
| 5              | R/W                                                       | R  | 0x0         | <b>FrameNumberOverflow Interrupt Enable</b> <table border="1"> <tr> <td>0</td><td>Ignore</td></tr> <tr> <td>1</td><td>Enable interrupt generation due to Frame Number Over Flow</td></tr> </table>                                                 | 0 | Ignore | 1 | Enable interrupt generation due to Frame Number Over Flow |
| 0              | Ignore                                                    |    |             |                                                                                                                                                                                                                                                    |   |        |   |                                                           |
| 1              | Enable interrupt generation due to Frame Number Over Flow |    |             |                                                                                                                                                                                                                                                    |   |        |   |                                                           |
| 4              | R/W                                                       | R  | 0x0         | <b>UnrecoverableError Interrupt Enable</b> <table border="1"> <tr> <td>0</td><td>Ignore</td></tr> <tr> <td>1</td><td>Enable interrupt generation due to Unrecoverable Error</td></tr> </table>                                                     | 0 | Ignore | 1 | Enable interrupt generation due to Unrecoverable Error    |
| 0              | Ignore                                                    |    |             |                                                                                                                                                                                                                                                    |   |        |   |                                                           |
| 1              | Enable interrupt generation due to Unrecoverable Error    |    |             |                                                                                                                                                                                                                                                    |   |        |   |                                                           |
| 3              | R/W                                                       | R  | 0x0         | <b>ResumeDetected Interrupt Enable</b> <table border="1"> <tr> <td>0</td><td>Ignore</td></tr> <tr> <td>1</td><td>Enable interrupt generation due to Resume Detected</td></tr> </table>                                                             | 0 | Ignore | 1 | Enable interrupt generation due to Resume Detected        |
| 0              | Ignore                                                    |    |             |                                                                                                                                                                                                                                                    |   |        |   |                                                           |
| 1              | Enable interrupt generation due to Resume Detected        |    |             |                                                                                                                                                                                                                                                    |   |        |   |                                                           |

| Offset: 0x0410 |                                                         |    |             | Register Name: O_HcInterruptEnable                                                                                                                   |
|----------------|---------------------------------------------------------|----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write                                              |    | Default/Hex | Description                                                                                                                                          |
|                | HCD                                                     | HC |             |                                                                                                                                                      |
| 2              | R/W                                                     | R  | 0x0         | StartofFrame Interrupt Enable                                                                                                                        |
|                |                                                         |    |             | <table border="1"> <tr> <td>0</td><td>Ignore</td></tr> <tr> <td>1</td><td>Enable interrupt generation due to Start of Flame</td></tr> </table>       |
| 0              | Ignore                                                  |    |             |                                                                                                                                                      |
| 1              | Enable interrupt generation due to Start of Flame       |    |             |                                                                                                                                                      |
| 1              | R/W                                                     | R  | 0x0         | WritebackDoneHead Interrupt Enable                                                                                                                   |
|                |                                                         |    |             | <table border="1"> <tr> <td>0</td><td>Ignore</td></tr> <tr> <td>1</td><td>Enable interrupt generation due to Write back Done Head</td></tr> </table> |
| 0              | Ignore                                                  |    |             |                                                                                                                                                      |
| 1              | Enable interrupt generation due to Write back Done Head |    |             |                                                                                                                                                      |
| 0              | R/W                                                     | R  | 0x0         | SchedulingOverrun Interrupt Enable                                                                                                                   |
|                |                                                         |    |             | <table border="1"> <tr> <td>0</td><td>Ignore</td></tr> <tr> <td>1</td><td>Enable interrupt generation due to Scheduling Overrun</td></tr> </table>   |
| 0              | Ignore                                                  |    |             |                                                                                                                                                      |
| 1              | Enable interrupt generation due to Scheduling Overrun   |    |             |                                                                                                                                                      |

#### 8.9.6.5 0x0414 OHCI Interrupt Disable Register (Default Value: 0x0000\_0000)

| Offset: 0x0414 |                                                            |    |             | Register Name: O_HcInterruptDisable                                                                                                                                                                                                             |
|----------------|------------------------------------------------------------|----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write                                                 |    | Default/Hex | Description                                                                                                                                                                                                                                     |
|                | HCD                                                        | HC |             |                                                                                                                                                                                                                                                 |
| 31             | R/W                                                        | R  | 0x0         | MasterInterruptEnable<br>A written '0' to this field is ignored by HC. A '1' written to this field disables interrupt generation due events specified in the other bits of this register. This field is set after a hardware or software reset. |
|                |                                                            |    |             | /                                                                                                                                                                                                                                               |
| 30:7           | /                                                          | /  | /           | RootHubStatusChange Interrupt Disable                                                                                                                                                                                                           |
|                |                                                            |    |             | <table border="1"> <tr> <td>0</td><td>Ignore</td></tr> <tr> <td>1</td><td>Disable interrupt generation due to Root Hub Status Change</td></tr> </table>                                                                                         |
| 0              | Ignore                                                     |    |             |                                                                                                                                                                                                                                                 |
| 1              | Disable interrupt generation due to Root Hub Status Change |    |             |                                                                                                                                                                                                                                                 |
| 6              | R/W                                                        | R  | 0x0         | FrameNumberOverflow Interrupt Disable                                                                                                                                                                                                           |
|                |                                                            |    |             | <table border="1"> <tr> <td>0</td><td>Ignore</td></tr> <tr> <td>1</td><td>Disable interrupt generation due to Frame Number Over Flow</td></tr> </table>                                                                                         |
| 0              | Ignore                                                     |    |             |                                                                                                                                                                                                                                                 |
| 1              | Disable interrupt generation due to Frame Number Over Flow |    |             |                                                                                                                                                                                                                                                 |
| 5              | R/W                                                        | R  | 0x0         | UnrecoverableError Interrupt Disable                                                                                                                                                                                                            |
|                |                                                            |    |             | <table border="1"> <tr> <td>0</td><td>Ignore</td></tr> <tr> <td>1</td><td>Disable interrupt generation due to Unrecoverable Error</td></tr> </table>                                                                                            |
| 0              | Ignore                                                     |    |             |                                                                                                                                                                                                                                                 |
| 1              | Disable interrupt generation due to Unrecoverable Error    |    |             |                                                                                                                                                                                                                                                 |
| 4              | R/W                                                        | R  | 0x0         | ResumeDetected Interrupt Disable                                                                                                                                                                                                                |
|                |                                                            |    |             | <table border="1"> <tr> <td>0</td><td>Ignore</td></tr> </table>                                                                                                                                                                                 |
| 0              | Ignore                                                     |    |             |                                                                                                                                                                                                                                                 |
| 3              | R/W                                                        | R  | 0x0         |                                                                                                                                                                                                                                                 |

| Offset: 0x0414 |            |    |             | Register Name: O_HcInterruptDisable |                                                          |
|----------------|------------|----|-------------|-------------------------------------|----------------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                         |                                                          |
|                | HCD        | HC |             |                                     |                                                          |
|                |            |    |             | 1                                   | Disable interrupt generation due to Resume Detected      |
| 2              | R/W        | R  | 0x0         | StartofFrame Interrupt Disable      |                                                          |
|                |            |    |             | 0                                   | Ignore                                                   |
|                |            |    |             | 1                                   | Disable interrupt generation due to Start of Flame       |
| 1              | R/W        | R  | 0x0         | WritebackDoneHead Interrupt Disable |                                                          |
|                |            |    |             | 0                                   | Ignore                                                   |
|                |            |    |             | 1                                   | Disable interrupt generation due to Write back Done Head |
| 0              | R/w        | R  | 0x0         | SchedulingOverrun Interrupt Disable |                                                          |
|                |            |    |             | 0                                   | Ignore                                                   |
|                |            |    |             | 1                                   | Disable interrupt generation due to Scheduling Overrun   |

#### 8.9.6.6 0x0418 OHCI HCCA Register (Default Value: 0x0000\_0000)

| Offset: 0x0418 |            |    |             | Register Name: O_HcHCCA                                                                                                                                                                                                                                   |
|----------------|------------|----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                                                                                                                                                                                                                                               |
|                | HCD        | HC |             |                                                                                                                                                                                                                                                           |
| 31:8           | R/W        | R  | 0x0         | <p><b>HCCA [31:8]</b><br/> This is the base address of the Host Controller Communication Area. This area is used to hold the control structures and the Interrupt table that are accessed by both the Host Controller and the Host Controller Driver.</p> |
| 7:0            | R          | R  | 0x0         | <p><b>HCCA [7:0]</b><br/> The alignment restriction in HcHCCA register is evaluated by examining the number of zeros in the lower order bits. The minimum alignment is 256 bytes, therefore, bits 0 through 7 must always return 0 when read.</p>         |

#### 8.9.6.7 0x041C OHCI Period Current ED Register (Default Value: 0x0000\_0000)

| Offset: 0x041C |            |    |             | Register Name: O_HcPeriodCurrentED |
|----------------|------------|----|-------------|------------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                        |
|                | HCD        | HC |             |                                    |

| Offset: 0x041C |            |     |             | Register Name: O_HcPeriodCurrentED                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                         |
|                | HCD        | HC  |             |                                                                                                                                                                                                                                                                                                                                     |
| 31:4           | R          | R/W | 0x0         | <b>PCED [31:4]</b><br>This is used by HC to point to the head of one of the Periodic list which will be processed in the current Frame. The content of this register is updated by HC after a periodic ED has been processed. HCD may read the content in determining which ED is currently being processed at the time of reading. |
| 3:0            | R          | R   | 0x0         | <b>PCED [3:0]</b><br>Because the general TD length is 16 bytes, the memory structure for the TD must be aligned to a 16-byte boundary. So the lower bits in the PCED, through bit 0 to bit 3 must be zero in this field.                                                                                                            |

#### 8.9.6.8 0x0420 OHCI Control Head ED Register (Default Value: 0x0000\_0000)

| Offset: 0x0420 |            |    |             | Register Name: O_HcControlHeadED                                                                                                                                                                                                                                                |
|----------------|------------|----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                                                                                                                                                                                                                                                                     |
|                | HCD        | HC |             |                                                                                                                                                                                                                                                                                 |
| 31:4           | R/W        | R  | 0x0         | <b>EHCD [31:4]</b><br>The HcControlHeadED register contains the physical address of the first Endpoint Descriptor of the Control list. HC traverse the Control list starting with the HcControlHeadED pointer. The content is loaded from HCCA during the initialization of HC. |
| 3:0            | R          | R  | 0x0         | <b>EHCD [3:0]</b><br>Because the general TD length is 16 bytes, the memory structure for the TD must be aligned to a 16-byte boundary. So the lower bits in the PCED, through bit 0 to bit 3 must be zero in this field.                                                        |

#### 8.9.6.9 0x0424 OHCI Control Current ED Register (Default Value: 0x0000\_0000)

| Offset: 0x0424 |            |     |             | Register Name: HcControlCurrentED[CCED]                                                                                         |
|----------------|------------|-----|-------------|---------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |     | Default/Hex | Description                                                                                                                     |
|                | HCD        | HC  |             |                                                                                                                                 |
| 31:4           | R/W        | R/W | 0x0         | <b>CCED[31:4]</b><br>The pointer is advanced to the next ED after serving the present one. HC will continue processing the list |

| Offset: 0x0424 |            |    |             | Register Name: HcControlCurrentED[CCED]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------|------------|----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                | HCD        | HC |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                |            |    |             | <p>from where it left off in the last Frame. When it reaches the end of the Control list, HC checks the ControlListFilled of in HcCommandStatus. If set, it copies the content of HcControlHeadED to HcControlCurrentED and clears the bit. If not set, it does nothing.</p> <p>HCD is allowed to modify this register only when the ControlListEnable of HcControl is cleared. When set, HCD only reads the instantaneous value of this register. Initially, this is set to zero to indicate the end of the Control list.</p> |
| 3:0            | R          | R  | 0x0         | <p><b>CCED[3:0]</b></p> <p>Because the general TD length is 16 bytes, the memory structure for the TD must be aligned to a 16-byte boundary. So the lower bits in the PCED, through bit 0 to bit 3 must be zero in this field.</p>                                                                                                                                                                                                                                                                                             |

#### 8.9.6.10 0x0428 OHCI Bulk Head ED Register (Default Value: 0x0000\_0000)

| Offset: 0x0428 |            |    |             | Register Name: O_HcBulkHeadED[BHED]                                                                                                                                                                                                                                             |
|----------------|------------|----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                                                                                                                                                                                                                                                                     |
|                | HCD        | HC |             |                                                                                                                                                                                                                                                                                 |
| 31:4           | R/W        | R  | 0x0         | <p><b>BHED [31:4]</b></p> <p>The HcBulkHeadED register contains the physical address of the first Endpoint Descriptor of the Bulk list. HC traverses the Bulk list starting with the HcBulkHeadED pointer. The content is loaded from HCCA during the initialization of HC.</p> |
| 3:0            | R          | R  | 0x0         | <p><b>BHED [3:0]</b></p> <p>Because the general TD length is 16 bytes, the memory structure for the TD must be aligned to a 16-byte boundary. So the lower bits in the PCED, through bit 0 to bit 3 must be zero in this field.</p>                                             |

#### 8.9.6.11 0x042C OHCI Bulk Current ED Register (Default Value: 0x0000\_0000)

| Offset: 0x042C |            |             | Register Name: O_HcBulkCurrentED[BCED] |
|----------------|------------|-------------|----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                            |
|                |            |             |                                        |

|      | HCD | HC  |     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|-----|-----|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:4 | R/W | R/W | 0x0 | <p><b>BulkCurrentED [31:4]</b><br/>           This is advanced to the next ED after the HC has served the present one. HC continues processing the list from where it left off in the last Frame. When it reaches the end of the Bulk list, HC checks the <b>ControlListFilled</b> of <i>HcControl</i>. If set, it copies the content of <i>HcBulkHeadED</i> to <i>HcBulkCurrentED</i> and clears the bit. If it is not set, it does nothing. HCD is only allowed to modify this register when the <b>BulkListEnable</b> of <i>HcControl</i> is cleared. When set, the HCD only reads the instantaneous value of this register. This is initially set to zero to indicate the end of the Bulk list.</p> |
| 3:0  | R   | R   | 0x0 | <p><b>BulkCurrentED [3:0]</b><br/>           Because the general TD length is 16 bytes, the memory structure for the TD must be aligned to a 16-byte boundary. So the lower bits in the PCED, through bit 0 to bit 3 must be zero in this field.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

#### 8.9.6.12 0x0430 OHCI Done Head Register (Default Value: 0x0000\_0000)

| Offset: 0x0430 |            |     |             | Register Name: O_HcDoneHead                                                                                                                                                                                                                                                                                                                                                           |
|----------------|------------|-----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                           |
|                | HCD        | HC  |             |                                                                                                                                                                                                                                                                                                                                                                                       |
| 31:4           | R          | R/W | 0x0         | <p><b>HcDoneHead [31:4]</b><br/>           When a TD is completed, HC writes the content of <i>HcDoneHead</i> to the NextTD field of the TD. HC then overwrites the content of <i>HcDoneHead</i> with the address of this TD. This is set to zero whenever HC writes the content of this register to HCCA. It also sets the <b>WritebackDoneHead</b> of <i>HcInterruptStatus</i>.</p> |
| 3:0            | R          | R   | 0x0         | <p><b>HcDoneHead [3:0]</b><br/>           Because the general TD length is 16 bytes, the memory structure for the TD must be aligned to a 16-byte boundary. So the lower bits in the PCED, through bit 0 to bit 3 must be zero in this field.</p>                                                                                                                                     |

#### 8.9.6.13 0x0434 OHCI Frame Interval Register (Default Value: 0x0000\_2EDF)

| Offset: 0x0434 |            |             | Register Name: O_HcFmInterval Register |
|----------------|------------|-------------|----------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                            |

|       | HCD | HC |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------|-----|----|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | R/W | R  | 0x0    | <b>FrameIntervalToggler</b><br>HCD toggles this bit whenever it loads a new value to <b>FrameInterval</b> .                                                                                                                                                                                                                                                                                                                                     |
| 30:16 | R/W | R  | 0x0    | <b>FSLargestDataPacket</b><br>This field specifies a value which is loaded into the Largest Data Packet Counter at the beginning of each frame. The counter value represents the largest amount of data in bits which can be sent or received by the HC in a single transaction at any given time without causing scheduling overrun. The field value is calculated by the HCD.                                                                 |
| 15:14 | /   | /  | /      | /                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 13:0  | R/W | R  | 0x2edf | <b>FrameInterval</b><br>This specifies the interval between two consecutive SOFs in bit times. The nominal value is set to be 11,999. HCD should store the current value of this field before resetting HC. By setting the <b>HostControllerReset</b> field of <i>HcCommandStatus</i> as this will cause the HC to reset this field to its nominal value. HCD may choose to restore the stored value upon the completion of the Reset sequence. |

#### 8.9.6.14 0x0438 OHCI Frame Remaining Register (Default Value: 0x0000\_0000)

| Offset: 0x0438 |            |     |             | Register Name: O_HcFmRemaining                                                                                                                                                                                                                                                                                                                                                        |
|----------------|------------|-----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                           |
|                | HCD        | HC  |             |                                                                                                                                                                                                                                                                                                                                                                                       |
| 31             | R          | R/W | 0x0         | <b>FrameRemaining Toggle</b><br>This bit is loaded from the <b>FrameIntervalToggle</b> field of <i>HcFmInterval</i> whenever <b>FrameRemaining</b> reaches 0. This bit is used by HCD for the synchronization between <b>FrameInterval</b> and <b>FrameRemaining</b> .                                                                                                                |
| 30:14          | /          | /   | /           | /                                                                                                                                                                                                                                                                                                                                                                                     |
| 13:0           | R          | RW  | 0x0         | <b>FrameRemaining</b><br>This counter is decremented at each bit time. When it reaches zero, it is reset by loading the <b>FrameInterval</b> value specified in <i>HcFmInterval</i> at the next bit time boundary. When entering the USBOPERATIONAL state, HC re-loads the content with the <b>FrameInterval</b> of <i>HcFmInterval</i> and uses the updated value from the next SOF. |

## 8.9.6.15 0x043C OHCI Frame Number Register (Default Value: 0x0000\_0000)

| Offset: 0x043C |            |     |             | Register Name: O_HcFmNumber                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|------------|-----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                | HCD        | HC  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 31:16          | /          | /   | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 15:0           | R          | R/W | 0x0         | <p><b>FrameNumber</b><br/> This is incremented when <i>HcFmRemaining</i> is re-loaded. It will be rolled over to 0x0 after 0xffff. When entering the USBOPERATIONAL state, this will be incremented automatically. The content will be written to HCCA after HC has incremented the <b>FrameNumber</b> at each frame boundary and sent a SOF but before HC reads the first ED in that Frame. After writing to HCCA, HC will set the <b>StartofFrame</b> in <i>HcInterruptStatus</i>.</p> |

## 8.9.6.16 0x0440 OHCI Periodic Start Register (Default Value: 0x0000\_0000)

| Offset: 0x0440 |            |    |             | Register Name: O_HcPeriodicStatus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                | HCD        | HC |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 31:14          | /          | /  | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 13:0           | R/W        | R  | 0x0         | <p><b>PeriodicStart</b><br/> After a hardware reset, this field is cleared. This is then set by HCD during the HC initialization. The value is calculated roughly as 10% off from <i>HcFmInterval</i>. A typical value will be 0xA3F (or 0xe67). When <i>HcFmRemaining</i> reaches the value specified, processing of the periodic lists will have priority over Control/Bulk processing. HC will therefore start processing the Interrupt list after completing the current Control or Bulk transaction that is in progress.</p> |

## 8.9.6.17 0x0444 OHCI LS Threshold Register (Default Value: 0x0000\_0628)

| Offset: 0x0444 |            |    |             | Register Name: O_HcLSThreshold |
|----------------|------------|----|-------------|--------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                    |
|                | HCD        | HC |             |                                |
| 31:12          | /          | /  | /           | /                              |

| Offset: 0x0444 |            |    |             | Register Name: O_HcLSThreshold                                                                                                                                                                                                                                                                                                              |
|----------------|------------|----|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                 |
|                | HCD        | HC |             |                                                                                                                                                                                                                                                                                                                                             |
| 11:0           | R/W        | R  | 0x0628      | <b>LSThreshold</b><br>This field contains a value which is compared to the <b>FrameRemaining</b> field prior to initiating a Low Speed transaction. The transaction is started only if <b>FrameRemaining</b> is less than or equal to this field. The value is calculated by HCD with the consideration of transmission and setup overhead. |

#### 8.9.6.18 0x0448 OHCI Root Hub DescriptorA Register (Default Value: 0x0200\_1201)

| Offset: 0x0448 |                                                                        |    |             | Register Name: O_HcRhDescriptorA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                                                                        |   |                                                    |
|----------------|------------------------------------------------------------------------|----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|------------------------------------------------------------------------|---|----------------------------------------------------|
| Bit            | Read/Write                                                             |    | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |   |                                                                        |   |                                                    |
|                | HCD                                                                    | HC |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |                                                                        |   |                                                    |
| 31:24          | R/W                                                                    | R  | 0x2         | <b>PowerOnToPowerGoodTime[POTPGT]</b><br>This byte specifies the duration HCD has to wait before accessing a powered-on port of the Root Hub. It is implementation-specific. The unit of time is 2 ms. The duration is calculated as POTPGT * 2ms.                                                                                                                                                                                                                                                                                        |   |                                                                        |   |                                                    |
| 23:13          | /                                                                      | /  | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |   |                                                                        |   |                                                    |
| 12             | R/W                                                                    | R  | 0x1         | <b>NoOverCurrentProtection</b><br>This bit describes how the overcurrent status for the Root Hub ports are reported. When this bit is cleared, the <b>OverCurrentProtectionMode</b> field specifies global or per-port reporting. <table border="1" data-bbox="754 1426 1421 1560"> <tr> <td>0</td><td>Over-current status is reported collectively for all downstream ports.</td></tr> <tr> <td>1</td><td>No overcurrent protection supported.</td></tr> </table>                                                                        | 0 | Over-current status is reported collectively for all downstream ports. | 1 | No overcurrent protection supported.               |
| 0              | Over-current status is reported collectively for all downstream ports. |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |                                                                        |   |                                                    |
| 1              | No overcurrent protection supported.                                   |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |                                                                        |   |                                                    |
| 11             | R/W                                                                    | R  | 0x0         | <b>OverCurrentProtectionMode</b><br>This bit describes how the overcurrent status for the Root Hub ports are reported. At reset, these fields should reflect the same mode as <b>PowerSwitchingMode</b> . This field is valid only if the <b>NoOverCurrentProtection</b> field is cleared. <table border="1" data-bbox="754 1819 1421 1987"> <tr> <td>0</td><td>Over-current status is reported collectively for all downstream ports.</td></tr> <tr> <td>1</td><td>Over-current status is reported on per-port basis.</td></tr> </table> | 0 | Over-current status is reported collectively for all downstream ports. | 1 | Over-current status is reported on per-port basis. |
| 0              | Over-current status is reported collectively for all downstream ports. |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |                                                                        |   |                                                    |
| 1              | Over-current status is reported on per-port basis.                     |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |                                                                        |   |                                                    |
| 10             | R                                                                      | R  | 0x0         | <b>Device Type</b><br>This bit specifies that the Root Hub is not a compound                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |                                                                        |   |                                                    |

| Offset: 0x0448 |                                                                                                                                                                                                                                                                                                                                                                        |    |             | Register Name: O_HcRhDescriptorA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |                                         |   |                                                                                                                                                                                                                                                                                                                                                                        |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|-----------------------------------------|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write                                                                                                                                                                                                                                                                                                                                                             |    | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |   |                                         |   |                                                                                                                                                                                                                                                                                                                                                                        |
|                | HCD                                                                                                                                                                                                                                                                                                                                                                    | HC |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |                                         |   |                                                                                                                                                                                                                                                                                                                                                                        |
|                |                                                                                                                                                                                                                                                                                                                                                                        |    |             | device. The Root Hub is not permitted to be a compound device. This field should always read/write 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |                                         |   |                                                                                                                                                                                                                                                                                                                                                                        |
| 9              | R/W                                                                                                                                                                                                                                                                                                                                                                    | R  | 0x1         | <p><b>PowerSwitchingMode</b><br/> This bit is used to specify how the power switching of the Root Hub ports is controlled. It is implementation-specific. This field is only valid if the <b>NoPowerSwitching</b> field is cleared.</p> <table border="1"> <tr> <td>0</td><td>All ports are powered at the same time.</td></tr> <tr> <td>1</td><td>Each port is powered individually. This mode allows port power to be controlled by either the global switch or per-port switching. If the <b>PortPowerControlMask</b> bit is set, the port responds only to port power commands (Set/ClearPortPower). If the port mask is cleared, then the port is controlled only by the global power switch (Set/ClearGlobalPower).</td></tr> </table> | 0 | All ports are powered at the same time. | 1 | Each port is powered individually. This mode allows port power to be controlled by either the global switch or per-port switching. If the <b>PortPowerControlMask</b> bit is set, the port responds only to port power commands (Set/ClearPortPower). If the port mask is cleared, then the port is controlled only by the global power switch (Set/ClearGlobalPower). |
| 0              | All ports are powered at the same time.                                                                                                                                                                                                                                                                                                                                |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |                                         |   |                                                                                                                                                                                                                                                                                                                                                                        |
| 1              | Each port is powered individually. This mode allows port power to be controlled by either the global switch or per-port switching. If the <b>PortPowerControlMask</b> bit is set, the port responds only to port power commands (Set/ClearPortPower). If the port mask is cleared, then the port is controlled only by the global power switch (Set/ClearGlobalPower). |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |                                         |   |                                                                                                                                                                                                                                                                                                                                                                        |
| 8              | R/W                                                                                                                                                                                                                                                                                                                                                                    | R  | 0x0         | <p><b>NoPowerSwitching</b><br/> These bits are used to specify whether power switching is supported or ports are always powered. It is implementation-specific. When this bit is cleared, the <b>PowerSwitchingMode</b> specifies global or per-port switching.</p> <table border="1"> <tr> <td>0</td><td>Ports are power switched.</td></tr> <tr> <td>1</td><td>Ports are always powered on when the HC is powered on.</td></tr> </table>                                                                                                                                                                                                                                                                                                   | 0 | Ports are power switched.               | 1 | Ports are always powered on when the HC is powered on.                                                                                                                                                                                                                                                                                                                 |
| 0              | Ports are power switched.                                                                                                                                                                                                                                                                                                                                              |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |                                         |   |                                                                                                                                                                                                                                                                                                                                                                        |
| 1              | Ports are always powered on when the HC is powered on.                                                                                                                                                                                                                                                                                                                 |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |                                         |   |                                                                                                                                                                                                                                                                                                                                                                        |
| 7:0            | R                                                                                                                                                                                                                                                                                                                                                                      | R  | 0x01        | <p><b>NumberDownstreamPorts</b><br/> These bits specify the number of downstream ports supported by the Root Hub. It is implementation-specific. The minimum number of ports is 1. The maximum number of ports supported.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |                                         |   |                                                                                                                                                                                                                                                                                                                                                                        |

#### 8.9.6.19 0x044C HcRhDescriptorB Register (Default Value: 0x0000\_0000)

| Offset: 0x044C |            |    |             | Register Name: O_HcRhDescriptorB Register |
|----------------|------------|----|-------------|-------------------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                               |
|                | HCD        | HC |             |                                           |
| 31:16          | R/W        | R  | 0x0         | PortPowerControlMask                      |

| Offset: 0x044C |                                |    |             | Register Name: O_HcRhDescriptorB Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |          |      |                               |      |                               |     |  |       |                                |
|----------------|--------------------------------|----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------|------|-------------------------------|------|-------------------------------|-----|--|-------|--------------------------------|
| Bit            | Read/Write                     |    | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |      |          |      |                               |      |                               |     |  |       |                                |
|                | HCD                            | HC |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |          |      |                               |      |                               |     |  |       |                                |
|                |                                |    |             | <p>Each bit indicates if a port is affected by a global power control command when PowerSwitchingMode is set. When set, the port's power state is only affected by per-port power control (Set/ClearPortPower). When cleared, the port is controlled by the global power switch (Set/ClearGlobalPower). If the device is configured to global switching mode (PowerSwitchingMode = 0 ), this field is not valid.</p> <table border="1"> <tr> <td>Bit0</td><td>Reserved</td></tr> <tr> <td>Bit1</td><td>Ganged-power mask on Port #1.</td></tr> <tr> <td>Bit2</td><td>Ganged-power mask on Port #2.</td></tr> <tr> <td>...</td><td></td></tr> <tr> <td>Bit15</td><td>Ganged-power mask on Port #15.</td></tr> </table> | Bit0 | Reserved | Bit1 | Ganged-power mask on Port #1. | Bit2 | Ganged-power mask on Port #2. | ... |  | Bit15 | Ganged-power mask on Port #15. |
| Bit0           | Reserved                       |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |          |      |                               |      |                               |     |  |       |                                |
| Bit1           | Ganged-power mask on Port #1.  |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |          |      |                               |      |                               |     |  |       |                                |
| Bit2           | Ganged-power mask on Port #2.  |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |          |      |                               |      |                               |     |  |       |                                |
| ...            |                                |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |          |      |                               |      |                               |     |  |       |                                |
| Bit15          | Ganged-power mask on Port #15. |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |          |      |                               |      |                               |     |  |       |                                |
| 15:0           | R/W                            | R  | 0x0         | <p>DeviceRemovable</p> <p>Each bit is dedicated to a port of the Root Hub. When cleared, the attached device is removable. When set, the attached device is not removable.</p> <table border="1"> <tr> <td>Bit0</td><td>Reserved</td></tr> <tr> <td>Bit1</td><td>Device attached to Port #1.</td></tr> <tr> <td>Bit2</td><td>Device attached to Port #2.</td></tr> <tr> <td>...</td><td></td></tr> <tr> <td>Bit15</td><td>Device attached to Port #15.</td></tr> </table>                                                                                                                                                                                                                                             | Bit0 | Reserved | Bit1 | Device attached to Port #1.   | Bit2 | Device attached to Port #2.   | ... |  | Bit15 | Device attached to Port #15.   |
| Bit0           | Reserved                       |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |          |      |                               |      |                               |     |  |       |                                |
| Bit1           | Device attached to Port #1.    |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |          |      |                               |      |                               |     |  |       |                                |
| Bit2           | Device attached to Port #2.    |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |          |      |                               |      |                               |     |  |       |                                |
| ...            |                                |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |          |      |                               |      |                               |     |  |       |                                |
| Bit15          | Device attached to Port #15.   |    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |          |      |                               |      |                               |     |  |       |                                |

#### 8.9.6.20 0x0450 HcRhStatus Register (Default Value: 0x0000\_0000)

| Offset: 0x0450 |            |    |             | Register Name: O_HcRhStatus Register                                                                                                                                                                                              |
|----------------|------------|----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                                                                                                                                                                                                                       |
|                | HCD        | HC |             |                                                                                                                                                                                                                                   |
| 31             | W          | R  | 0x0         | <p>(write)ClearRemoteWakeUpEnable</p> <p>Write a '1' clears DeviceRemoteWakeUpEnable.</p> <p>Writing a '0' has no effect.</p>                                                                                                     |
| 30:18          | /          | /  | /           | /                                                                                                                                                                                                                                 |
| 17             | R/W        | R  | 0x0         | <p>OverCurrentIndicatorChange</p> <p>This bit is set by hardware when a change has occurred to the OverCurrentIndicator field of this register. The HCD clears this bit by writing a '1'.</p> <p>Writing a '0' has no effect.</p> |

| Offset: 0x0450 |                                                          |     |             | Register Name: O_HcRhStatus Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |                                                          |   |                                                      |
|----------------|----------------------------------------------------------|-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|----------------------------------------------------------|---|------------------------------------------------------|
| Bit            | Read/Write                                               |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |                                                          |   |                                                      |
|                | HCD                                                      | HC  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |   |                                                          |   |                                                      |
| 16             | R/W                                                      | R   | 0x0         | <p><b>(read)LocalPowerStartusChange</b><br/>                     The Root Hub does not support the local power status features, thus, this bit is always read as '0'.</p> <p><b>(write)SetGlobalPower</b><br/>                     In global power mode (<b>PowerSwitchingMode</b>=0), This bit is written to '1' to turn on power to all ports (clear <b>PortPowerStatus</b>). In per-port power mode, it sets <b>PortPowerStatus</b> only on ports whose <b>PortPowerControlMask</b> bit is not set. Writing a '0' has no effect.</p>                                                          |   |                                                          |   |                                                      |
| 15             | R/W                                                      | R   | 0x0         | <p><b>(read)DeviceRemoteWakeupEnable</b><br/>                     This bit enables a <b>ConnectStatusChange</b> bit as a resume event, causing a USBSUSPEND to USBRESUME state transition and setting the <b>ResumeDetected</b> interrupt.</p> <table border="1"> <tr> <td>0</td><td><b>ConnectStatusChange</b> is not a remote wakeup event.</td></tr> <tr> <td>1</td><td><b>ConnectStatusChange</b> is a remote wakeup event.</td></tr> </table> <p><b>(write)SetRemoteWakeupEnable</b><br/>                     Writing a '1' sets DeviceRemoveWakeupEnable. Writing a '0' has no effect.</p> | 0 | <b>ConnectStatusChange</b> is not a remote wakeup event. | 1 | <b>ConnectStatusChange</b> is a remote wakeup event. |
| 0              | <b>ConnectStatusChange</b> is not a remote wakeup event. |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |   |                                                          |   |                                                      |
| 1              | <b>ConnectStatusChange</b> is a remote wakeup event.     |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |   |                                                          |   |                                                      |
| 14:2           | /                                                        | /   | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |                                                          |   |                                                      |
| 1              | R                                                        | R/W | 0x0         | <p><b>OverCurrentIndicator</b><br/>                     This bit reports overcurrent conditions when the global reporting is implemented. When set, an overcurrent condition exists. When cleared, all power operations are normal.<br/>                     If per-port overcurrent protection is implemented this bit is always '0'</p>                                                                                                                                                                                                                                                        |   |                                                          |   |                                                      |
| 0              | R/W                                                      | R   | 0x0         | <p><b>(Read)LocalPowerStatus</b><br/>                     When read, this bit returns the LocalPowerStatus of the Root Hub. The Root Hub does not support the local power status feature; thus, this bit is always read as '0'.</p> <p><b>(Write)ClearGlobalPower</b><br/>                     When write, this bit is operated as the ClearGlobalPower. In global power mode (<b>PowerSwitchingMode</b>=0), This bit is written to '1' to</p>                                                                                                                                                   |   |                                                          |   |                                                      |

| Offset: 0x0450 |            |    |             | Register Name: O_HcRhStatus Register                                                                                                                                                         |
|----------------|------------|----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write |    | Default/Hex | Description                                                                                                                                                                                  |
|                | HCD        | HC |             |                                                                                                                                                                                              |
|                |            |    |             | turn off power to all ports (clear PortPowerStatus). In per-port power mode, it clears PortPowerStatus only on ports whose PortPowerControlMask bit is not set. Writing a '0' has no effect. |

#### 8.9.6.21 0x0454 HcRhPortStatus Register (Default Value: 0x0000\_0100)

| Offset: 0x0454 |                                       |     |             | Register Name: O_HcRhPortStatus                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                                       |   |                                      |
|----------------|---------------------------------------|-----|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------------------------------------|---|--------------------------------------|
| Bit            | Read/Write                            |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |                                       |   |                                      |
|                | HCD                                   | HC  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                                       |   |                                      |
| 31:21          | /                                     | /   | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |                                       |   |                                      |
| 20             | R/W                                   | R/W | 0x0         | <p>PortResetStatusChange<br/>This bit is set at the end of the 10-ms port reset signal. The HCD writes a '1' to clear this bit. Writing a '0' has no effect.</p> <table border="1"> <tr> <td>0</td><td>port reset is not complete</td></tr> <tr> <td>1</td><td>port reset is complete</td></tr> </table>                                                                                                                                                 | 0 | port reset is not complete            | 1 | port reset is complete               |
| 0              | port reset is not complete            |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                                       |   |                                      |
| 1              | port reset is complete                |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                                       |   |                                      |
| 19             | R/W                                   | R/W | 0x0         | <p>PortOverCurrentIndicatorChange<br/>This bit is valid only if overcurrent conditions are reported on a per-port basis. This bit is set when Root Hub changes the PortOverCurrentIndicator bit. The HCD writes a '1' to clear this bit. Writing a '0' has no effect.</p> <table border="1"> <tr> <td>0</td><td>no change in PortOverCurrentIndicator</td></tr> <tr> <td>1</td><td>PortOverCurrentIndicator has changed</td></tr> </table>               | 0 | no change in PortOverCurrentIndicator | 1 | PortOverCurrentIndicator has changed |
| 0              | no change in PortOverCurrentIndicator |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                                       |   |                                      |
| 1              | PortOverCurrentIndicator has changed  |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                                       |   |                                      |
| 18             | R/W                                   | R/W | 0x0         | <p>PortSuspendStatusChange<br/>This bit is set when the full resume sequence has been completed. This sequence includes the 20-s resume pulse, LS EOP, and 3-ms resynchronization delay. The HCD writes a '1' to clear this bit. Writing a '0' has no effect. This bit is also cleared when ResetStatusChange is set.</p> <table border="1"> <tr> <td>0</td><td>resume is not completed</td></tr> <tr> <td>1</td><td>resume completed</td></tr> </table> | 0 | resume is not completed               | 1 | resume completed                     |
| 0              | resume is not completed               |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                                       |   |                                      |
| 1              | resume completed                      |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                          |   |                                       |   |                                      |
| 17             | R/W                                   | R/W | 0x0         | <p>PortEnableStatusChange<br/>This bit is set when hardware events cause the PortEnableStatus bit to be cleared. Changes from HCD writes do not set this bit. The HCD writes a '1' to clear this bit. Writing a '0' has no effect.</p>                                                                                                                                                                                                                   |   |                                       |   |                                      |

| Offset: 0x0454 |                               |     |             | Register Name: O_HcRhPortStatus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |                               |   |                            |
|----------------|-------------------------------|-----|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|-------------------------------|---|----------------------------|
| Bit            | Read/Write                    |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |   |                               |   |                            |
|                | HCD                           | HC  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |                               |   |                            |
|                |                               |     |             | <table border="1"> <tr> <td>0</td><td>no change in PortEnableStatus</td></tr> <tr> <td>1</td><td>change in PortEnableStatus</td></tr> </table>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0 | no change in PortEnableStatus | 1 | change in PortEnableStatus |
| 0              | no change in PortEnableStatus |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |                               |   |                            |
| 1              | change in PortEnableStatus    |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |                               |   |                            |
| 16             | R/W                           | R/W | 0x0         | <p>ConnectStatusChange<br/>This bit is set whenever a connect or disconnect event occurs. The HCD writes a '1' to clear this bit. Writing a '0' has no effect. If CurrentConnectStatus is cleared when a SetPortReset,SetPortEnable, or SetPortSuspend write occurs, this bit is set to force the driver to re-evaluate the connection status since these writes should not occur if the port is disconnected.</p> <table border="1"> <tr> <td>0</td><td>no change in PortEnableStatus</td></tr> <tr> <td>1</td><td>change in PortEnableStatus</td></tr> </table> <p><b>Note:</b> If the DeviceRemovable[NDP] bit is set, this bit is set only after a Root Hub reset to inform the system that the device is attached.</p> | 0 | no change in PortEnableStatus | 1 | change in PortEnableStatus |
| 0              | no change in PortEnableStatus |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |                               |   |                            |
| 1              | change in PortEnableStatus    |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |                               |   |                            |
| 15:10          | /                             | /   | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |                               |   |                            |
| 9              | R/W                           | R/W | 0x0         | <p>(read)LowSpeedDeviceAttached<br/>This bit indicates the speed of the device attached to this port. When set, a Low Speed device is attached to this port. When clear, a Full Speed device is attached to this port. This field is valid only when the CurrentConnectStatus is set.</p> <table border="1"> <tr> <td>0</td><td>full speed device attached</td></tr> <tr> <td>1</td><td>low speed device attached</td></tr> </table> <p>(write)ClearPortPower<br/>The HCD clears the PortPowerStatus bit by writing a '1' to this bit. Writing a '0' has no effect.</p>                                                                                                                                                     | 0 | full speed device attached    | 1 | low speed device attached  |
| 0              | full speed device attached    |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |                               |   |                            |
| 1              | low speed device attached     |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |   |                               |   |                            |
| 8              | R/W                           | R/W | 0x1         | <p>(read)PortPowerStatus<br/>This bit reflects the port's power status, regardless of the type of power switching implemented. This bit is cleared if an overcurrent condition is detected. HCD sets this bit by writing SetPortPower or SetGlobalPower. HCD clears this bit by writing ClearPortPower or ClearGlobalPower. Which power control switches are enabled is determined by PowerSwitchingMode and</p>                                                                                                                                                                                                                                                                                                            |   |                               |   |                            |

| Offset: 0x0454 |                                 |     |             | Register Name: O_HcRhPortStatus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |   |                                 |   |                             |
|----------------|---------------------------------|-----|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------------------------------|---|-----------------------------|
| Bit            | Read/Write                      |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |   |                                 |   |                             |
|                | HCD                             | HC  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |   |                                 |   |                             |
|                |                                 |     |             | <p>PortPortControlMask[NumberDownstreamPort]. In global switching mode(PowerSwitchingMode=0), only Set/ClearGlobalPower controls this bit. In per-port power switching (PowerSwitchingMode=1), if the PortPowerControlMask[NDP] bit for the port is set, only Set/ClearPortPower commands are enabled. If the mask is not set, only Set/ClearGlobalPower commands are enabled. When port power is disabled, CurrentConnectStatus, PortEnableStatus, PortSuspendStatus, and PortResetStatus should be reset.</p> <table border="1"> <tr> <td>0</td><td>port power is off</td></tr> <tr> <td>1</td><td>port power is on</td></tr> </table> <p>(write)SetPortPower<br/>The HCD writes a '1' to set the PortPowerStatus bit. Writing a '0' has no effect.</p> <p><b>Note:</b> This bit is always reads '1b' if power switching is not supported.</p> | 0 | port power is off               | 1 | port power is on            |
| 0              | port power is off               |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |   |                                 |   |                             |
| 1              | port power is on                |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |   |                                 |   |                             |
| 7:5            | /                               | /   | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |                                 |   |                             |
| 4              | R/W                             | R/W | 0x0         | <p>(read)PortResetStatus<br/>When this bit is set by a write to SetPortReset, port reset signaling is asserted. When reset is completed, this bit is cleared when PortResetStatusChange is set. This bit cannot be set if CurrentConnectStatus is cleared.</p> <table border="1"> <tr> <td>0</td><td>port reset signal is not active</td></tr> <tr> <td>1</td><td>port reset signal is active</td></tr> </table> <p>(write)SetPortReset<br/>The HCD sets the port reset signaling by writing a '1' to this bit. Writing a '0' has no effect. If CurrentConnectStatus is cleared, this write does not set PortResetStatus, but instead sets ConnectStatusChange. This informs the driver that it attempted to reset a disconnected port.</p>                                                                                                      | 0 | port reset signal is not active | 1 | port reset signal is active |
| 0              | port reset signal is not active |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |   |                                 |   |                             |
| 1              | port reset signal is active     |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |   |                                 |   |                             |
| 3              | R/W                             | R/W | 0x0         | (read)PortOverCurrentIndicator<br>This bit is only valid when the Root Hub is configured                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |   |                                 |   |                             |

| Offset: 0x0454 |                                 |     |             | Register Name: O_HcRhPortStatus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |                           |   |                                 |
|----------------|---------------------------------|-----|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------------------------|---|---------------------------------|
| Bit            | Read/Write                      |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |   |                           |   |                                 |
|                | HCD                             | HC  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |                           |   |                                 |
|                |                                 |     |             | <p>in such a way that overcurrent conditions are reported on a per-port basis. If per-port overcurrent reporting is not supported, this bit is set to 0. If cleared, all power operations are normal for this port. If set, an overcurrent condition exists on this port.</p> <p>This bit always reflects the overcurrent input signal.</p> <table border="1"> <tr> <td>0</td><td>no overcurrent condition.</td></tr> <tr> <td>1</td><td>overcurrent condition detected.</td></tr> </table> <p>(write)ClearSuspendStatus</p> <p>The HCD writes a '1' to initiate a resume. Writing a '0' has no effect. A resume is initiated only if PortSuspendStatus is set.</p>                                                                                                                                                                                                                                                                                                          | 0 | no overcurrent condition. | 1 | overcurrent condition detected. |
| 0              | no overcurrent condition.       |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |                           |   |                                 |
| 1              | overcurrent condition detected. |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |                           |   |                                 |
| 2              | R/W                             | R/W | 0x0         | <p>(read)PortSuspendStatus</p> <p>This bit indicates the port is suspended or in the resume sequence. It is set by a SetSuspendState write and cleared when PortSuspendStatusChange is set at the end of the resume interval. This bit cannot be set if CurrentConnectStatus is cleared. This bit is also cleared when PortResetStatusChange is set at the end of the port reset or when the HC is placed in the USBRESUME state. If an upstream resume is in progress, it should propagate to the HC.</p> <table border="1"> <tr> <td>0</td><td>port is not suspended</td></tr> <tr> <td>1</td><td>port is suspended</td></tr> </table> <p>(write)SetPortSuspend</p> <p>The HCD sets the PortSuspendStatus bit by writing a '1' to this bit. Writing a '0' has no effect. If CurrentConnectStatus is cleared, this write does not set PortSuspendStatus; instead it sets ConnectStatusChange. This informs the driver that it attempted to suspend a disconnected port.</p> | 0 | port is not suspended     | 1 | port is suspended               |
| 0              | port is not suspended           |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |                           |   |                                 |
| 1              | port is suspended               |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |   |                           |   |                                 |
| 1              | R/W                             | R/W | 0x0         | <p>(read)PortEnableStatus</p> <p>This bit indicates whether the port is enabled or disabled. The Root Hub may clear this bit when an overcurrent condition, disconnect event, switched-off power, or operational bus error such as babble is detected. This change also causes</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |   |                           |   |                                 |

| Offset: 0x0454 |                     |     |             | Register Name: O_HcRhPortStatus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |                     |   |                  |
|----------------|---------------------|-----|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------------------|---|------------------|
| Bit            | Read/Write          |     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |   |                     |   |                  |
|                | HCD                 | HC  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |                     |   |                  |
|                |                     |     |             | <p>PortEnabledStatusChange to be set. HCD sets this bit by writing SetPortEnable and clears it by writing ClearPortEnable. This bit cannot be set when CurrentConnectStatus is cleared. This bit is also set, if not already, at the completion of a port reset when ResetStatusChange is set or port suspend when SuspendStatusChange is set.</p> <table border="1"> <tr> <td>0</td><td>port is disabled</td></tr> <tr> <td>1</td><td>port is enabled</td></tr> </table> <p>(write)SetPortEnable<br/>The HCD sets PortEnableStatus by writing a '1'. Writing a '0' has no effect. If CurrentConnectStatus is cleared, this write does not set PortEnableStatus, but instead sets ConnectStatusChange. This informs the driver that it attempted to enable a disconnected Port.</p> | 0 | port is disabled    | 1 | port is enabled  |
| 0              | port is disabled    |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |                     |   |                  |
| 1              | port is enabled     |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |                     |   |                  |
| 0              | R/W                 | R/W | 0x0         | <p>(read)CurrentConnectStatus<br/>This bit reflects the current state of the downstream port.</p> <table border="1"> <tr> <td>0</td><td>No device connected</td></tr> <tr> <td>1</td><td>Device connected</td></tr> </table> <p>(write)ClearPortEnable<br/>The HCD writes a '1' to clear the PortEnableStatus bit. Writing '0' to this bit has no effect. The CurrentConnectStatus is not affected by any write.<br/>Note: This bit is always read '1' when the attached device is nonremovable<br/>(DviceRemoveable[NumberDownstreamPort]).</p>                                                                                                                                                                                                                                    | 0 | No device connected | 1 | Device connected |
| 0              | No device connected |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |                     |   |                  |
| 1              | Device connected    |     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |                     |   |                  |

## 8.9.7 HCI Controller and PHY Interface Description

### 8.9.7.1 0x0800 HCI Interface Register (Default Value: 0x1000\_0000)

| Offset: 0x0800 |            |             | Register Name: USB_CTRL                                                                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                        |
| 31             | R/W        | 0x0         | USB Standby Clock Sel<br>0x0: normal mode usb clock as usual<br>0x1: standby mode usb clock switch to RC 16M clock |

| Offset: 0x0800 |            |             | Register Name: USB_CTRL                                                                                                                                                                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                        |
| 30:29          | /          | /           | Reserved                                                                                                                                                                                                                                           |
| 28             | R          | 1           | DMA Transfer Status Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                              |
| 27:26          | /          | /           | /                                                                                                                                                                                                                                                  |
| 25             | R/W        | 0           | OHCI count select<br>1: Simulation mode. The counters will be much shorter than real time<br>0: Normal mode. The counters will count full time                                                                                                     |
| 24:19          | /          | /           | /                                                                                                                                                                                                                                                  |
| 18             | R/W        | 0           | 1: Within 2 us of the resume-K to SE0 transition<br>0: Random time value of the resume-K to SE0 transition                                                                                                                                         |
| 17:13          | /          | /           | /                                                                                                                                                                                                                                                  |
| 12             | R/W        | 0           | PP2VBUS<br>1: ULPI wrapper interface will automatically set or clear DrvVbus register in ULPI PHY according to the port power status from the root hub<br>0: ULPI wrapper will ignore the difference between power status of root hub and ULPI PHY |
| 11             | R/W        | 0           | AHB Master interface INCR16 enable<br>1: Use INCR16 when appropriate<br>0: Do not use INCR16, use other enabled INCRX or unspecified length burst INCR                                                                                             |
| 10             | R/W        | 0           | AHB Master interface INCR8 enable<br>1: Use INCR8 when appropriate<br>0: Do not use INCR8, use other enabled INCRX or unspecified length burst INCR                                                                                                |
| 9              | R/W        | 0           | AHB Master interface burst type INCR4 enable<br>1: Use INCR4 when appropriate<br>0: Do not use INCR4, use other enabled INCRX or unspecified length burst INCR                                                                                     |
| 8              | R/W        | 0           | AHB Master interface INCRX align enable<br>1: Start INCRx burst only on burst x-align address<br>0: Start burst on any double word boundary<br>Note: This bit must enable if any bit of bit[11:9] is enabled                                       |
| 7:4            | /          | /           | /                                                                                                                                                                                                                                                  |
| 3              | R/W        | 0x0         | RC Clock Gating<br>0x0: clock gated<br>0x1: clock un gated                                                                                                                                                                                         |

| Offset: 0x0800 |            |             | Register Name: USB_CTRL                                                                                                    |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                |
| 2              | R/W        | 0x0         | RC Generation Enable<br>0x0: disable<br>0x1: enable                                                                        |
| 1              | /          | /           | /                                                                                                                          |
| 0              | R/W        | 0           | ULPI bypass enable<br>1: Enable UTMI interface, disable ULPI interface<br>0: Enable ULPI interface, disable UTMI interface |

#### 8.9.7.2 0x0808 HCI Control 3 Register (Default Value: 0x0001\_0000)

| Offset: 0x0808 |            |             | Register Name: HCI_CTRL3                                                                                                   |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                |
| 31:17          | /          | /           | Reserved                                                                                                                   |
| 16             | R/W1C      | 0           | Linestate Change Detect<br>0: Linestate change not detected<br>1: Linestate change detected<br>Write '1' to clear.         |
| 15:10          | /          | /           | Reserved                                                                                                                   |
| 9              | R/W        | 0           | Forcesusp<br>1: Susp_Sel is valid. PHY could be configured into suspend mode when Susp_Sel = 0.<br>0: Susp_Sel is invalid. |
| 8              | R/W        | 0           | Susp_Sel<br>1: Normal operating mode(PHY)<br>0: Suspend Mode(PHY)<br>This bit is valid when forcesusp=1.                   |
| 7:4            | /          | /           | /                                                                                                                          |
| 3              | R/W        | 0           | Remote Wakeup Enable<br>1: Enable<br>0: Disable                                                                            |
| 2              | /          | /           | Reserved                                                                                                                   |
| 1              | R/W        | 0           | Linestate Change Interrupt Enable<br>1: Enable<br>0: Disable                                                               |
| 0              | R/W        | 0           | Linestate Change Detect Enable<br>1: Enable<br>0: Disable                                                                  |

#### 8.9.7.3 0x0810 PHY Control Register (Default Value: 0x0000\_0018)

| Offset: 0x0810 |            |             | Register Name: PHY_CTL                                  |
|----------------|------------|-------------|---------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                             |
| 31:9           | /          | /           | /                                                       |
| 8              | R/W        | 0           | VREGBYPASS                                              |
| 7              | R/W        | 0           | LOOPBACKENB                                             |
| 6              | R/W        | 0           | IDPULLUP                                                |
| 5              | R/W        | 0           | VBUSVLDEXT                                              |
| 4              | R/W        | 1           | VBUSVLDEXTSEL                                           |
|                |            |             | SIDDQ                                                   |
| 3              | R/W        | 1           | 1: Write 1 to disable phy.<br>0: Write 0 to enable phy. |
| 2              | R/W        | 0           | COMMONN                                                 |
| 1:0            | R/W        | 0           | VATESTENB                                               |

#### 8.9.7.4 0x0814 PHY Test Register (Default Value:0x0000\_0000)

| Offset: 0x0814 |            |             | Register Name: PHY_TEST |
|----------------|------------|-------------|-------------------------|
| Bit            | Read/Write | Default/Hex | Description             |
| 31:15          | /          | /           | /                       |
| 14             | R/W        | 0x0         | TESTBURNIN              |
| 13             | R/W        | 0x0         | TESTDATAOUTSEL          |
| 12             | R/W        | 0x0         | TESTCLK                 |
| 11:8           | R/W        | 0x0         | TESTADDR                |
| 7:0            | R/W        | 0x0         | TESTDATAIN              |

#### 8.9.7.5 0x0818 PHY Tune Register (Default Value:0x05B3\_33D4)

| Offset: 0x0818 |            |             | Register Name: PHY_TUNE |
|----------------|------------|-------------|-------------------------|
| Bit            | Read/Write | Default/Hex | Description             |
| 31:28          | /          | /           | /                       |
| 27:26          | R/W        | 0x1         | VDATREFTUNE[1:0]        |
| 25:23          | R/W        | 0x3         | COMPDISTUNE[2:0]        |
| 22:20          | R/W        | 0x3         | SQRXTUNE[2:0]           |
| 19             | R/W        | 0x0         | TXPREEMPPULSE TUNE      |
| 18:16          | R/W        | 0x3         | OTGTUNE[2:0]            |
| 15:12          | R/W        | 0x3         | TXFSLSTUNE[3:0]         |
| 11:8           | R/W        | 0x3         | TXVREFTUNE[3:0]         |
| 7:6            | R/W        | 0x3         | TXHSXVTUNE[1:0]         |
| 5:4            | R/W        | 0x1         | TXRISETUNE[1:0]         |

| Offset: 0x0818 |            |             | Register Name: PHY_TUNE |
|----------------|------------|-------------|-------------------------|
| Bit            | Read/Write | Default/Hex | Description             |
| 3:2            | R/W        | 0x1         | TXRESTUNE[1:0]          |
| 1:0            | R/W        | 0x0         | TXPREEMPAMPTUNE[1:0]    |

#### 8.9.7.6 0x0824 PHY Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0824 |            |             | Register Name: PHY_STA |
|----------------|------------|-------------|------------------------|
| Bit            | Read/Write | Default/Hex | Description            |
| 31:4           | /          | /           | /                      |
| 3:0            | R          | 0           | TESTDATAOUT            |

#### 8.9.7.7 0x0828 HCI SIE Port Disable Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0828 |            |             | Register Name: USB_SPDCR                                                                                                                                                                                                                               |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                            |
| 31:17          | /          | /           | /                                                                                                                                                                                                                                                      |
| 16             | R/W        | 0           | SE0 Status<br>This bit is set when no-se0 is detected before SOF when bit[1:0] is 10b or 11b                                                                                                                                                           |
| 15:5           | /          | /           | /                                                                                                                                                                                                                                                      |
| 4              | R/W        | 0           | resume_sel<br>When set k-se0 transition 2 us, setting this bit to 1, which is cooperated with ss_utmi_backward_enb_i.                                                                                                                                  |
| 3:2            | /          | /           | /                                                                                                                                                                                                                                                      |
| 1:0            | R/W        | 0           | Port Disable Control<br>00: Port Disable when no-se0 detect before SOF<br>01: Port Disable when no-se0 detect before SOF<br>10: No Port Disable when no-se0 detect before SOF<br>11: Port Disable when no-se0 3 time detect before SOF during 8 frames |

## 8.10 PCIe2.1&USB3.1 Top System

### 8.10.1 Overview

The PCIe2.1&USB3.1 top system integrates a PCIe2.1 RC controller and a USB3.1 DRD controller with a Combo PHY which supports PCIe GEN1 GEN2 and USB3.1 GEN1 speed and is shared through PIPE interface.

### 8.10.2 Block Diagram

The following figure shows the block diagram of PCIe2.1&USB3.1 top system.

**Figure 8-40 PCIe2.1&USB3.1 Top System Block Diagram**



**NOTE**

This chapter focuses on the 1 PCIe2.1&USB3.1 combo PHY. For the detailed description of PCIe2.1 and USB3.1 DRD, please refer to section 8.12 PCIe2.1 and section 8.11 USB3.1 DRD.

### 8.10.3 Register List

| Module Name       | Base Address |
|-------------------|--------------|
| PCIE_USB3_TOP_APP | 0x04F00000   |

| Register Name | Offset | Description |
|---------------|--------|-------------|
|               |        |             |

| Register Name | Offset | Description                    |
|---------------|--------|--------------------------------|
| PCIEBGR       | 0x0004 | PCIE Bus Gating Reset Register |
| USB3BGR       | 0x0008 | USB3 Bus Gating Reset Register |
| PHYCTL        | 0x0010 | PHY Control Register           |
| PHYSTS0       | 0x0080 | PHY Status Register 0          |
| PHYSTS1       | 0x0084 | PHY Status Register 1          |
| PHYSTS2       | 0x0088 | PHY Status Register 2          |

#### 8.10.4 Register Description

##### 8.10.4.1 0x0004 PCIE Bus Gating Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: PCIEBGR                |
|----------------|------------|-------------|---------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                           |
| 31:18          | /          | /           | /                                     |
| 17             | R/W        | 0x0         | PCIE_ACLK_EN<br>PCIE AXI Clock Enable |
| 16             | R/W        | 0x0         | PCIE_HCLK_EN<br>PCIE AHB Clock Enable |
| 15:2           | /          | /           | /                                     |
| 1              | R/W        | 0x0         | PCIE_PERSTN                           |
| 0              | R/W        | 0x0         | PCIE_POWER_UP_RSTN                    |

##### 8.10.4.2 0x0008 USB3 Bus Gating Reset Register (Default Value:0x0000\_0000)

| Offset: 0x0008 |            |             | Register Name: USB3BGR                |
|----------------|------------|-------------|---------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                           |
| 31:18          | /          | /           | /                                     |
| 17             | R/W        | 0x0         | USB3_ACLK_EN<br>USB3 AXI Clock Enable |
| 16             | R/W        | 0x0         | USB3_HCLK_EN<br>USB3 AHB Clock Enable |
| 15:1           | /          | /           | /                                     |
| 0              | R/W        | 0x0         | USB3_RESETN                           |

##### 8.10.4.3 0x0010 PHY Control Register (Default Value:0x0000\_0000)

| Offset: 0x0010 |            |             | Register Name: PHYCTL |
|----------------|------------|-------------|-----------------------|
| Bit            | Read/Write | Default/Hex | Description           |

| Offset: 0x0010 |            |             | Register Name: PHYCTL                                                                                                                    |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                              |
| 31             | R/W        | 0x0         | PHY_USE_SEL<br>0: PHY used by PCIE<br>1: PHY used by USB3                                                                                |
| 30             | R/W        | 0x0         | PHY_REFCLK_SEL<br>0: PHY uses internal single end reference clock<br>1: PHY uses external differential reference clock                   |
| 29:17          | /          | /           | /                                                                                                                                        |
| 16             | R/W        | 0x0         | PHY_BIST_EN                                                                                                                              |
| 15:10          | /          | /           | /                                                                                                                                        |
| 9              | R/W        | 0x0         | PHY PIPE_RSTN_SW                                                                                                                         |
| 8              | R/W        | 0x0         | PHY_PIPE_RSTN_SEL<br>0: PHY PIPE resetn is controlled by PCIE or USB3 Controller<br>1: PHY PIPE resetn is controlled by PHY_PIPE_RSTN_SW |
| 7:5            | /          | /           | /                                                                                                                                        |
| 4              | R/W        | 0x0         | PHY_PIPE_CLK_INVERT                                                                                                                      |
| 3:1            | /          | /           | /                                                                                                                                        |
| 0              | R/W        | 0x0         | PHY_RSTN<br>Combo PHY Power On RESET_N                                                                                                   |

#### 8.10.4.4 0x0080 PHY Status Register 0 (Default Value:0x0000\_0000)

| Offset: 0x0080 |            |             | Register Name: PHYSTS0            |
|----------------|------------|-------------|-----------------------------------|
| Bit            | Read/Write | Default/Hex | Description                       |
| 31             | R/W1C      | 0x0         | PHY_PIPE_PHYSTATUS_ASSERT_PENDING |
| 30             | R          | 0x0         | PHY_PIPE_PHYSTATUS                |
| 29:2           | /          | /           | /                                 |
| 1              | R          | 0x0         | PHY_BIST_PASS                     |
| 0              | R          | 0x0         | PHY_BIST_DONE                     |

#### 8.10.4.5 0x0084 PHY Status Register 1 (Default Value:0x0000\_0000)

| Offset: 0x0084 |            |             | Register Name: PHYSTS1 |
|----------------|------------|-------------|------------------------|
| Bit            | Read/Write | Default/Hex | Description            |
| 31             | R/W        | 0x0         | PHY_PIPE_RX_DBG_EN     |
| 30:7           | /          | /           | /                      |
| 6              | R          | 0x0         | PHY_PIPE_RXELECIDLE    |
| 5              | R          | 0x0         | PHY_PIPE_RXVALID       |
| 4              | R          | 0x0         | PHY_PIPE_RXDATAVALID   |

| Offset: 0x0084 |            |             | Register Name: PHYSTS1 |
|----------------|------------|-------------|------------------------|
| Bit            | Read/Write | Default/Hex | Description            |
| 3:0            | R          | 0x0         | PHY_PIPE_RXDATAK       |

#### 8.10.4.6 0x0088 PHY Status Register 2 (Default Value:0x0000\_0000)

| Offset: 0x0088 |            |             | Register Name: PHYSTS2 |
|----------------|------------|-------------|------------------------|
| Bit            | Read/Write | Default/Hex | Description            |
| 31:0           | R          | 0x0         | PHY_PIPE_RXDATA        |

## 8.11 USB3.1 DRD

### 8.11.1 Overview

The USB3.1 DRD is a Dual-Role Device (DRD) controller, which supports both device and host functions which can also be configured as a host-only or device-only controller, fully compliant with the USB 3.1 Specification. It can support super-speed (SS, 5-Gbit/s), high-speed (HS, 480-Mbit/s), full-speed (FS, 12-Mbit/s), and low-speed (LS, 1.5-Mbit/s) transfers in Host mode. It can support super-speed (SS, 5-Gbit/s), high-speed (HS, 480-Mbit/s), and full-speed (FS, 12-Mbit/s) in Device mode. Standard USB transceiver can be used through its UTMI+ interface and PIPE interface.

The USB3 DRD controller includes the following features:

- Compliant with USB3.1 GEN1 Specification
- One USB 2.0 UTMI+ PHY (USB2)
- One USB3.1 PIPE PHY (USB3)
- USB3.1 DRD Device mode supports the following:
  - Super-Speed (SS, 5 Gbit/s) for USB3.1 PHY
  - High-Speed (HS, 480 Mbit/s) and Full-Speed (FS, 12-Mbit/s) for USB2.0 PHY
- USB3.1 DRD HOST mode supports the following:
  - Super-Speed (SS, 5 Gbit/s) for USB3.1 PHY
  - High-Speed (HS, 480 Mbit/s), Full-Speed (FS, 12 Mbit/s) and Low-Speed (LS, 1.5 Mbit/s) for USB2.0 PHY
- Support Device or Host operation at a time
- AXI interface for DMA operation
- Reading and writing access to Control and Status Registers (CSRs) through AHB Slave interface
- Up to 10 Endpoints, including bi-directional control Endpoint 0 in Device mode:
  - 5 IN Endpoints: User EP1 IN, EP2 IN, EP3 IN, EP4 IN, Control EP0 IN
  - 5 OUT Endpoints: User EP1 OUT, EP2 OUT, EP3 OUT, EP4 OUT, Control EP0 OUT
- Simultaneous IN and OUT transfer in Super-Speed mode
- Dual-port interfaces for TX data buffering, RX data prefetching, descriptor caching, and register caching
- Three RAMs: RX data FIFO RAM, TX data FIFO RAM, and descriptor/register Cache RAM
- Hardware handles all data transfer
- Implements both static and dynamic power reduction techniques at multiple levels



USB2.0 PHY and USB3.1 PHY share the same controller. They cannot be used simultaneously.

### 8.11.2 Block Diagram

The following figure shows the block diagram of USB3.1 DRD Controller

Figure 8-41 USB3.1 DRD Controller Block Diagram



### 8.11.3 Functional Description

#### 8.11.3.1 External Signals

Table 8-31 USB3.1 DRD External Signals

| Signal Name    | Description                                            | Type  |
|----------------|--------------------------------------------------------|-------|
| USB2-DM        | USB2.0 Data Signal DM                                  | A I/O |
| USB2-DP        | USB2.0 Data Signal DP                                  | A I/O |
| USB2-REXT      | USB2.0 External Reference Resistor                     | AO    |
| USB3-RXN       | USB3.1 SuperSpeed Differential Signal of RX (Negative) | AI    |
| USB3-RXP       | USB3.1 SuperSpeed Differential Signal of RX (Positive) | AI    |
| USB3-TXN       | SuperSpeed Differential Signal of TX (Negative)        | AO    |
| USB3-TXP       | USB3.1 SuperSpeed Differential Signal of TX (Positive) | AO    |
| VCC33-USB-2    | 3.3 V Power Supply for USB2.0 PHY                      | P     |
| VCC33-18-USB-2 | 3.3 V/1.8 V Power Supply for USB2.0 PHY                | P     |



## NOTE

For detailed functional information, please refer to *USB3.1 Specification*, *USB2.0 Specification*, and *extensible Host Controller Interface (XHCI) Specification, Version 1.1*.

#### 8.11.4 Register List

There are four groups of registers in USB3.1 DRD.

| Register Class                          | Offset                   |
|-----------------------------------------|--------------------------|
| <b>USB3 (0x04D0 0000---0x04EF FFFF)</b> |                          |
| xHCI Registers                          | 0x00000000 - 0x00007FFF  |
| Global Registers                        | 0x0000C100 - 0x0000C6FF  |
| Device Registers                        | 0x0000C700 - 0x0000CBFF  |
| Application Registers                   | 0x0010 0000 - 0x001007FF |

##### 8.11.4.1 xHCI Register List

| Register Class | Base Address            |
|----------------|-------------------------|
| xHCI Registers | 0x04D0 0000-0x04D0 7FFF |

| Register Name                     | Offset | Description                                                |
|-----------------------------------|--------|------------------------------------------------------------|
| <b>xHCI Capability Registers</b>  |        |                                                            |
| HCCLVER                           | 0x0000 | xHC Capability Length and Version Register                 |
| HCSPARAMS1                        | 0x0004 | xHC Structural Parameter 1 Register                        |
| HCSPARAMS2                        | 0x0008 | xHC Structural Parameters 2 Register                       |
| HCSPARAMS3                        | 0x000C | xHC Structural Parameters 3 Register                       |
| HCCPARAMS                         | 0x0010 | xHC Capability Parameters Register                         |
| DBOFF                             | 0x0014 | xHC Doorbell Offset Register                               |
| RTSOFF                            | 0x0018 | xHC Runtime Register Space Offset Register                 |
| HCCPARAMS2                        | 0x001C | xHC Capability Parameters 2 Register                       |
| <b>xHCI Operational Registers</b> |        |                                                            |
| HCUSBCMD                          | 0x0020 | xHC USB Command Register                                   |
| HCUSBSTS                          | 0x0024 | xHC USB Status Register                                    |
| HCPAGESIZE                        | 0x0028 | xHC Page Size Register                                     |
| HCDNCTRL                          | 0x0034 | xHC Device Notification Control Register                   |
| HCCRCLR                           | 0x0038 | xHC Command Ring Control Low Register                      |
| HCCRCHR                           | 0x003C | XHC Command Ring Control High Register                     |
| HCDCBAAPLR                        | 0x0050 | xHC Device Context Base Address Array Pointer Low Register |
| HCDCBAAPHR                        | 0x0054 | xHC Device Context Base Address Array Pointer High         |

| Register Name                               | Offset     | Description                                                         |
|---------------------------------------------|------------|---------------------------------------------------------------------|
|                                             |            | Register                                                            |
| HCCONFIG                                    | 0x0058     | xHC Configure Register                                              |
| HCPORT1SC                                   | 0x0420     | xHC Port1 Status and Control Register (USB2 Protocol)               |
| HCPORT1PMSC                                 | 0x0424     | xHC Port1 PM Status and Control Register (USB2 Protocol)            |
| HCPORT1LI                                   | 0x0428     | xHC Port1 Link Info Register (USB2 Protocol)                        |
| HCPORT2SC                                   | 0x0430     | xHC Port2 Status and Control Register (USB3 Protocol)               |
| HCPORT2PMSC                                 | 0x0434     | XHC Port2 PM Status and Control Register (USB3 Protocol)            |
| HCPORT2LI                                   | 0x0438     | xHC Port2 Link Info Register (USB3 Protocol)                        |
| <b>xHCI Runtime Registers</b>               |            |                                                                     |
| HCMFINDEX                                   | 0x1000     | xHC Microframe Index Register                                       |
| HCIMANO                                     | 0x1020     | xHC Interrupt 0 Management Register                                 |
| HCIMODO                                     | 0x1024     | xHC Interrupt 0 Moderation Register                                 |
| HCERSTSZ0                                   | 0x1028     | xHC Interrupt 0 Event Ring Segment Table Size Register              |
| HCERSTBAL0                                  | 0x1030     | xHC Interrupt 0 Event Ring Segment Table Base Address Low Register  |
| HCERSTBAH0                                  | 0x1034     | xHC Interrupt 0 Event Ring Segment Table Base Address High Register |
| HCERDPL0                                    | 0x1038     | xHC Interrupt 0 Event Ring Dequeue Pointer Low Register             |
| HCERDPH0                                    | 0x103C     | xHC Interrupt 0 Event Ring Dequeue Pointer High Register            |
| <b>xHCI Doorbell Registers</b>              |            |                                                                     |
| HCDBRn (n = 0 to 64)                        | 0x2000+4*n | XHC Doorbell Register n (n=0, 1,……, 64)                             |
| <b>xHCI Extended Capabilities Registers</b> |            |                                                                     |
| HCUSBLEGSUP                                 | 0x0440     | xHC USB Legacy Support Capability Register                          |
| HCUSBLEGCTRLSTS                             | 0x0444     | xHC USB Legacy Support Control/Status Register                      |
| HCSPC1REV                                   | 0x0490     | xHC Support Protocol Capability 1 Revision Register                 |
| HCSPC1STR                                   | 0x0494     | xHC Support Protocol Capability 1 String Register                   |
| HCSPC1PRT                                   | 0x0498     | xHC Support Protocol Capability 1 Port Register                     |
| HCSPC2REV                                   | 0x04A0     | xHC Support Protocol Capability 2 Revision Register                 |
| HCSPC2STR                                   | 0x04A4     | xHC Support Protocol Capability 2 String Register                   |
| HCSPC2PRT                                   | 0x04A8     | xHC Support Protocol Capability 3 Port Register                     |

## 8.11.4.2 Global Register List

| Register Class   | Base Address              |
|------------------|---------------------------|
| Global Registers | 0x04D0 C100 - 0x04D0 C6FF |

| Register Name   | Offset | Description                                                   |
|-----------------|--------|---------------------------------------------------------------|
| GSBUSCFG0       | 0xC100 | Global Soc Bus Configuration Register 0                       |
| GSBUSCFG1       | 0xC104 | Global Soc Bus Configuration Register 1                       |
| GTXTHRCFG       | 0xC108 | Global Tx Threshold Control Register                          |
| GRXTHRCFG       | 0xC10C | Global Rx Threshold Control Register                          |
| GCTL            | 0xC110 | Global Core Control Register                                  |
| GPMSTS          | 0xC114 | Global Power Management Status Register                       |
| GSTS            | 0xC118 | Global Status Register                                        |
| GUCTL1          | 0xC11C | Global User Control Register 1                                |
| GID             | 0xC120 | Global ID Register                                            |
| GGPIO           | 0xC124 | Global General Purpose Input/Output Register                  |
| GUID            | 0xC128 | Global User ID Register                                       |
| GUCTL           | 0xC12C | Global User Control Register                                  |
| GBUSERRADDR_Lo  | 0xC130 | Global Bus Error Address Low Register                         |
| GBUSERRADDR_Hi  | 0xC134 | Global Bus Error Address High Register                        |
| GPRTBIMAP_Lo    | 0xC138 | Global Super Speed Port to Bus Instance Mapping Low Register  |
| GPRTBIMAP_Hi    | 0xC13C | Global Super Speed Port to Bus Instance Mapping High Register |
| GDBGFIFOSPACE   | 0xC160 | Global Debug Queue/FIFO Space Available Register              |
| GBMUCTL         | 0xC164 | Global BMU Control Register                                   |
| GDBGBMU         | 0xC16C | Global Debug BMU Register                                     |
| GDBGLSPMUX      | 0xC170 | Global Debug LSP MUX Register                                 |
| GDBGLSP         | 0xC174 | Global Debug LSP Register                                     |
| GDBGEPINFO0     | 0xC178 | Global Debug Endpoint Information Register 0                  |
| GDBGEPINFO1     | 0xC17C | Global Debug Endpoint Information Register 1                  |
| GPRTBIMAP_HS_Lo | 0xC180 | Global High Speed Port to Bus Instance Mapping Low Register   |
| GPRTBIMAP_HS_Hi | 0xC184 | Global High Speed Port to Bus Instance Mapping High Register  |
| GPRTBIMAP_FS_Lo | 0xC188 | Global Full Speed Port to Bus Instance Mapping Low Register   |
| GPRTBIMAP_FS_Hi | 0xC18C | Global Full Speed Port to Bus Instance Mapping High Register  |
| GHMSOCBWOR      | 0xC190 | Global Host Mode SoC Bandwidth Override Register              |

| Register Name | Offset                                       | Description                                                                  |
|---------------|----------------------------------------------|------------------------------------------------------------------------------|
| GUSB2PHYCFGn  | 0xC200                                       | Global USB2 PHY Configuration Register                                       |
| GUSB3PIPECTLn | 0xC2C0                                       | Global USB3 PIPE Control Register                                            |
| GTXFIFOSIZ    | 0xC300+0x04*n<br>(n=FIFO_number)             | Global Transmit FIFO Size Register n<br>(n=FIFO_number)                      |
| GRXFIFOSIZ0   | 0xC380+0x04*n<br>(n=FIFO_number)             | Global Receive FIFO Size Register n<br>(n=FIFO_number)                       |
| GEVNTADLRn    | 0xC400+0x10*n<br>(0<= n <= EventBuff_number) | Global Event Buffer Address Lower Register n<br>(0<= n <= EventBuff_number)  |
| GEVNTADHRn    | 0xC404+0x10*n<br>(0<= n <= EventBuff_number) | Global Event Buffer Address Higher Register n<br>(0<= n <= EventBuff_number) |
| GEVNTSIZn     | 0xC408+0x10*n<br>(0<= n <= EventBuff_number) | Global Event Buffer Size Register n (0<= n <= EventBuff_number)              |
| GEVNTCOUNTn   | 0xC40C+0x10*n<br>(0<= n <= EventBuff_number) | Global Event Buffer Count Register n (0<= n <= EventBuff_number)             |
| GTXFIFOPRIDEV | 0xC610                                       | Global Device Tx FIFO DMA Priority Register                                  |
| GTXFIFOPRIHST | 0xC618                                       | Global Host Tx FIFO DMA Priority Register                                    |
| GRXFIFOPRIHST | 0xC61C                                       | Global Host Rx FIFO DMA Priority Register                                    |
| GDMAHLRATIO   | 0xC624                                       | Global Host FIFO DMA High-Low Priority Ratio Register                        |

#### 8.11.4.3 Device Register List

| Register Class   | Base Address              |
|------------------|---------------------------|
| Device Registers | 0x04D0 C700 - 0x04D0 CBFF |

| Register Name           | Offset        | Description                                             |
|-------------------------|---------------|---------------------------------------------------------|
| DCFG                    | 0xC700        | Device Configuration Register                           |
| DCTL                    | 0xC704        | Device Control Register                                 |
| DEVTEN                  | 0xC708        | Device Event Enable Register                            |
| DSTS                    | 0xC70C        | Device Status Register                                  |
| DGCMDPAR                | 0xC710        | Device Generic Command Parameter Register               |
| DGCMD                   | 0xC714        | Device Generic Command Register                         |
| DCTL1                   | 0xC718        | Device Control Register 1                               |
| DALEPENA                | 0xC720        | Device Active USB Endpoint Enable Register              |
| DLDMENA                 | 0xC724        | Device LDM Request Control Register                     |
| DEPCMDPAR2_n (n=0 to 9) | 0xC800+0x10*n | Device Physical Endpoint-n Command Parameter 2 Register |

| Register Name           | Offset          | Description                                             |
|-------------------------|-----------------|---------------------------------------------------------|
| DEPCMDPAR1_n (n=0 to 9) | 0xC804+0x0010*n | Device Physical Endpoint-n Command Parameter 1 Register |
| DEPCMDPAR0_n (n=0 to 9) | 0xC808+0x0010*n | Device Physical Endpoint-n Command Parameter 0 Register |
| DEPCMD_n (n=0 to 9)     | 0xC80c+0x0010*n | Device Physical Endpoint-n Command Register             |
| DEPIMOD                 | 0xCA00          | Device Interrupt Moderation Register                    |

#### 8.11.4.4 Application Register List

| Register Class        | Base Address             |
|-----------------------|--------------------------|
| Application Registers | 0x04E0 0000 - 0x04E007FF |

| Register Name | Offset   | Description                                  |
|---------------|----------|----------------------------------------------|
| U2_ISCR       | 0x100000 | USB2.0 Interface Status and Control Register |
| U2_PHYCTL     | 0x100010 | USB2.0 PHY Control Register                  |
| U2_PHYTST     | 0x100014 | USB2.0 PHY TEST Register                     |
| U2_PHYTUNE    | 0x100018 | USB2.0 PHY Tune Register                     |
| U2_PHYSTS     | 0x100024 | USB2.0 PHY Status Register                   |

#### 8.11.5 xHCI Register Description

##### 8.11.5.1 x0000 xHC Capability Length and Version Register (Default Value: 0x0110\_0020)

| Offset:0x0000 |            |             | Register Name: HCCLVER                                                                                                                                                                                                                                                                        |
|---------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                   |
| 31:16         | R          | 0x0110      | HCIVERSION<br>HC Interface Version Number<br>This is a 16-bits register containing a BCD encoding of the xHCI revision number supported by this host controller. The most significant byte of this register represents a major revision and the least significant byte is the minor revision. |
| 15:8          | /          | /           | /                                                                                                                                                                                                                                                                                             |
| 7:0           | R          | 0x20        | CAPLENGTH<br>Capability register Length<br>This register is used as an offset to add to register base to find the beginning of the Operational Register Space.                                                                                                                                |

### 8.11.5.2 0x0004 xHC Structural Parameters 1 Register (Default Value:0x0200\_0140)

| Offset: 0x0004 |            |             | Register Name: HCSPARAMS1                                                                                                                                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                           |
| 31:24          | R          | 0x02        | MaxPorts<br>Number of Ports<br>This field specifies the maximum Port Number value, i.e. the highest numbered Port Register Set that are addressable in the Operational Register Space |
| 23:19          | /          | /           | /                                                                                                                                                                                     |
| 18:8           | R          | 0x01        | MaxIntrs<br>Number of Interrupters<br>This field specifies the number of Interrupters implemented on this host controller                                                             |
| 7:0            | R          | 0x40        | MaxSlots<br>Number of Device Slots<br>This field specifies the maximum number of Device Context Structures and Doorbell Array entries this host controller can support.               |

### 8.11.5.3 0x0008 xHC Structural Parameters 2 Register (Default Value: 0x1400\_00F1)

| Offset: 0x0008 |            |             | Register Name: HCSPARAMS2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 31:27          | R          | 0x2         | Max Scratchpad Bufs Lo<br>Max Scratchpad Buffers Low<br>This field indicates the low order 5 bits of the number of Scratchpad Buffers system software shall reserve for the xHC                                                                                                                                                                                                                                                                                                                                                             |
| 26             | R          | 0x1         | SPR<br>Scratchpad Restore.<br>If <i>Max Scratchpad Buffers</i> is > '0' then this flag indicates whether the xHC uses the Scratchpad Buffers for saving state when executing Save and Restore State operations. If <i>Max Scratchpad Buffers</i> is = '0' then this flag shall be '0'.<br>A value of '1' indicates that the xHC requires the integrity of the Scratchpad Buffer space to be maintained across power events.<br>A value of '0' indicates that the Scratchpad Buffer space may be freed and reallocated between power events. |
| 25:21          | R          | 0           | Max Scratchpad Bufs Hi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

| Offset: 0x0008 |            |             | Register Name: HCSPARAMS2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                |            |             | Max Scratchpad Buffers High<br>This field indicates the high order 5 bits of the number of Scratchpad Buffers system software shall reserve for the xHC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 20:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 7:4            | R          | 0xF         | ERST Max<br>Event Ring Segment Table Max.<br>This field determines the maximum value supported the Event Ring Segment Table Base Size registers, where:<br>The maximum number of Event Ring Segment Table entries = $2^{\text{ERST Max}}$ .                                                                                                                                                                                                                                                                                                                                                                                                |
| 3:0            | R          | 0x1         | IST<br>Isochronous Scheduling Threshold.<br>The value in this field indicates to system software the minimum distance (in time) that it is required to stay ahead of the host controller while adding TRBs, in order to have the host controller process them at the correct time. The value shall be specified in terms of number of frames/ microframes. If bit [3] of IST is cleared to '0', software can add a TRB no later than IST [2:0] Microframes before that TRB is scheduled to be executed. If bit [3] of IST is set to '1', software can add a TRB no later than IST[2:0] Frames before that TRB is scheduled to be executed. |

#### 8.11.5.4 0x000C xHC Structural Parameters 3 Register (Default Value:0x0200\_000A)

| Offset: 0x000C |                         |             | Register Name: HCSPARAMS3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |             |       |      |       |                      |       |                      |     |  |       |                         |
|----------------|-------------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-------------|-------|------|-------|----------------------|-------|----------------------|-----|--|-------|-------------------------|
| Bit            | Read/Write              | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |             |       |      |       |                      |       |                      |     |  |       |                         |
| 31:16          | R                       | 0x0200      | <p>U2DEL<br/>U2 Device Exit Latency<br/>Worst case latency to transition from U2 to U0.<br/>Applies to all root hub ports. The following are permissible values:</p> <table> <thead> <tr> <th>Value</th> <th>Description</th> </tr> </thead> <tbody> <tr> <td>0000h</td> <td>Zero</td> </tr> <tr> <td>0001h</td> <td>Less than 1 <math>\mu</math>s.</td> </tr> <tr> <td>0002h</td> <td>Less than 2 <math>\mu</math>s.</td> </tr> <tr> <td>...</td> <td></td> </tr> <tr> <td>07FFh</td> <td>Less than 2047 <math>\mu</math>s.</td> </tr> </tbody> </table> | Value | Description | 0000h | Zero | 0001h | Less than 1 $\mu$ s. | 0002h | Less than 2 $\mu$ s. | ... |  | 07FFh | Less than 2047 $\mu$ s. |
| Value          | Description             |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       |             |       |      |       |                      |       |                      |     |  |       |                         |
| 0000h          | Zero                    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       |             |       |      |       |                      |       |                      |     |  |       |                         |
| 0001h          | Less than 1 $\mu$ s.    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       |             |       |      |       |                      |       |                      |     |  |       |                         |
| 0002h          | Less than 2 $\mu$ s.    |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       |             |       |      |       |                      |       |                      |     |  |       |                         |
| ...            |                         |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       |             |       |      |       |                      |       |                      |     |  |       |                         |
| 07FFh          | Less than 2047 $\mu$ s. |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       |             |       |      |       |                      |       |                      |     |  |       |                         |

| Offset: 0x000C |                       |             | Register Name: HCSPARAMS3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |       |             |     |      |     |                     |     |                      |     |  |     |                       |        |          |
|----------------|-----------------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-------------|-----|------|-----|---------------------|-----|----------------------|-----|--|-----|-----------------------|--------|----------|
| Bit            | Read/Write            | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |       |             |     |      |     |                     |     |                      |     |  |     |                       |        |          |
|                |                       |             | 0800-FFFFh Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |       |             |     |      |     |                     |     |                      |     |  |     |                       |        |          |
| 15:8           | /                     | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |             |     |      |     |                     |     |                      |     |  |     |                       |        |          |
| 7:0            | R                     | 0x0A        | <p>U1DEL<br/>U1 Device Exit Latency<br/>Worst case latency to transition a root hub Port Link State (PLS) from U1 to U0. Applies to all root hub ports. The following are permissible values:</p> <table> <thead> <tr> <th>Value</th> <th>Description</th> </tr> </thead> <tbody> <tr> <td>00h</td> <td>Zero</td> </tr> <tr> <td>01h</td> <td>Less than 1 <math>\mu</math>s</td> </tr> <tr> <td>02h</td> <td>Less than 2 <math>\mu</math>s.</td> </tr> <tr> <td>...</td> <td></td> </tr> <tr> <td>0Ah</td> <td>Less than 10 <math>\mu</math>s.</td> </tr> <tr> <td>0B-FFh</td> <td>Reserved</td> </tr> </tbody> </table> | Value | Description | 00h | Zero | 01h | Less than 1 $\mu$ s | 02h | Less than 2 $\mu$ s. | ... |  | 0Ah | Less than 10 $\mu$ s. | 0B-FFh | Reserved |
| Value          | Description           |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |             |     |      |     |                     |     |                      |     |  |     |                       |        |          |
| 00h            | Zero                  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |             |     |      |     |                     |     |                      |     |  |     |                       |        |          |
| 01h            | Less than 1 $\mu$ s   |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |             |     |      |     |                     |     |                      |     |  |     |                       |        |          |
| 02h            | Less than 2 $\mu$ s.  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |             |     |      |     |                     |     |                      |     |  |     |                       |        |          |
| ...            |                       |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |             |     |      |     |                     |     |                      |     |  |     |                       |        |          |
| 0Ah            | Less than 10 $\mu$ s. |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |             |     |      |     |                     |     |                      |     |  |     |                       |        |          |
| 0B-FFh         | Reserved              |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |       |             |     |      |     |                     |     |                      |     |  |     |                       |        |          |

#### 8.11.5.5 0x0010 xHC Capability Parameters Register (Default Value:0x0110\_FFCC)

| Offset: 0x0010 |            |             | Register Name: HCCPARAMS                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                         |
| 31:16          | R          | 0x0110      | <p>xECP<br/>xHCI Extended Capabilities Pointer<br/>This field indicates the existence of a capabilities list.<br/>The value of this field indicates a relative offset, in 32-bit words, for Base to the beginning of the first extended capability.<br/>Extended Capabilities Offset = xECP&lt;&lt;2 =0x0110&lt;&lt;2 = 0x0440.</p> |
| 15:12          | R          | 0xF         | <p>MaxPSASize<br/>Maximum Primary Stream Array Size<br/>This field identifies the maximum size Primary Stream Array that the xHC supports.<br/>The Primary Stream Array Size = <math>2^{\text{MaxPSASize}+1}</math>.<br/>Valid MaxPSASize values are 0 to 15, where '0' indicates that Streams are not supported</p>                |
| 11             | R          | 0x1         | <p>CFC<br/>Contiguous Frame ID Capability<br/>This flag indicates that the host controller implementation is capable of matching the Frame ID of consecutive Isoch TDs.</p>                                                                                                                                                         |
| 10             | R          | 0x1         | <p>SEC<br/>Stopped EDTLA Capability</p>                                                                                                                                                                                                                                                                                             |

| Offset: 0x0010 |            |             | Register Name: HCCPARAMS                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                |            |             | This flag indicates that the host controller implementation Stream Context support a Stopped EDTLA field.                                                                                                                                                                                                                                                                                                                             |
| 9              | R          | 0x1         | SPC<br>Stopped - Short Packet Capability<br>This flag indicates that the host controller implementation is capable of generating a <i>Stopped - Short Packet</i> Completion Code.                                                                                                                                                                                                                                                     |
| 8              | R          | 0x1         | PAE<br>Parse All Event Data<br>This flag indicates whether the host controller implementation Parses all Event Data TRBs while advancing to the next TD after a Short Packet, or it skips all but the first Event Data TRB. A '1' in this bit indicates that all Event Data TRBs are parsed. A '0' in this bit indicates that only the first Event Data TRB is parsed                                                                 |
| 7              | R          | 0x1         | NSS<br>No Secondary SID Support<br>This flag indicates whether the host controller implementation supports Secondary Stream IDs. A '1' in this bit indicates that Secondary Stream ID decoding is not supported. A '0' in this bit indicates that Secondary Stream ID decoding is supported.                                                                                                                                          |
| 6              | R          | 0x1         | LTC<br>Latency Tolerance Messaging Capability<br>This flag indicates whether the host controller implementation supports Latency Tolerance Messaging (LTM). A '1' in this bit indicates that LTM is supported. A '0' in this bit indicates that LTM is not supported.                                                                                                                                                                 |
| 5              | R          | 0x0         | LHRC<br>Light HC Reset Capability<br>This flag indicates whether the host controller implementation supports a Light Host Controller Reset. A '1' in this bit indicates that Light Host Controller Reset is supported. A '0' in this bit indicates that Light Host Controller Reset is not supported. The value of this flag affects the functionality of the <i>Light Host Controller Reset</i> (LHCRST) flag in the USBCMD register |

| Offset: 0x0010 |            |             | Register Name: HCCPARAMS                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                    |
| 4              | R          | 0x0         | PIND<br>Port Indicators<br>This bit indicates whether the xHC root hub ports support port indicator control. When this bit is a '1', the port status and control registers include a read/writeable field for controlling the state of the port indicator.                                                                                                                                                     |
| 3              | R          | 0x1         | PPC<br>Port Power Control<br>This flag indicates whether the host controller implementation includes port power control. A '1' in this bit indicates the ports have port power switches. A '0' in this bit indicates the port do not have port power switches. The value of this flag affects the functionality of the <i>PP</i> flag in each port status and control register                                 |
| 2              | R          | 0x1         | CSZ<br>Context Size<br>If this bit is set to '1', then the xHC uses 64-byte Context data structures. If this bit is cleared to '0', then the xHC uses 32-byte Context data structures.<br>Note: This flag does <i>not</i> apply to Stream Contexts.                                                                                                                                                            |
| 1              | R          | 0x0         | BNC<br>BW Negotiation Capability<br>This flag identifies whether the xHC has implemented the Bandwidth Negotiation. Values for this flag have the following interpretation:<br>Value      Description<br>0           BW Negotiation not implemented<br>1           BW Negotiation implemented                                                                                                                  |
| 0              | R          | 0x0         | AC64<br>64-bit Addressing Capability<br>This flag documents the addressing range capability of this implementation. The value of this flag determines whether the xHC has implemented the high order 32 bits of 64-bit register and data structure pointer fields. Values for this flag have the following interpretation:<br>Value      Description<br>0           32-bit address memory pointers implemented |

| Offset: 0x0010 |            |             | Register Name: HCCPARAMS                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                       |
|                |            |             | <p>1 64-bit address memory pointers implemented<br/> If 32-bit address memory pointers are implemented, the xHC shall ignore the high order 32 bits of 64 bit data structure pointer fields, and system software shall ignore the high order 32 bits of 64 bit xHC registers.</p> |

#### 8.11.5.6 0x0014 xHC Doorbell Offset Register (Default Value: 0x0000\_2000)

| Offset: 0x0014 |            |             | Register Name: HCDBOFF                                                                                                                |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                           |
| 31:2           | R          | 0x800       | <p>DBOFF<br/> Doorbell Array Offset<br/> This field defines the offset in Dwords of the Doorbell Array base address from the Base</p> |
| 1:0            | /          | /           | /                                                                                                                                     |

#### 8.11.5.7 0x0018 xHC Runtime Register Space Offset Register (Default Value: 0x0000\_1000)

| Offset: 0x0018 |            |             | Register Name: HCRTSOFF                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                              |
| 31:5           | R          | 0x80        | <p>RTSOFF<br/> Runtime Register Space Offset<br/> This field defines the 32-byte offset of the xHCI Runtime Registers from the Base.</p> |
| 4:0            | /          | /           | /                                                                                                                                        |

#### 8.11.5.8 0x001C xHC Capability Parameters 2 Register (Default Value: 0x0000\_003F)

| Offset: 0x001C |            |             | Register Name: HCCPARAMS2                                                                                                                                                                                                                                                           |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                         |
| 31:6           | /          | /           | /                                                                                                                                                                                                                                                                                   |
| 5              | R          | 0x1         | <p>CIC<br/> Configuration Information Capability.<br/> This bit indicates if the xHC supports extended Configuration Information. When this bit is 1, the <i>Configuration Value</i>, <i>Interface Number</i>, and <i>Alternate Setting</i> fields in the Input Control Context</p> |

| Offset: 0x001C |            |             | Register Name: HCCPARAMS2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                |            |             | are supported. When this bit is 0, the extended Input Control Context fields are not supported.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 4              | R          | 0x1         | <p>LEC</p> <p>Large ESIT Payload Capability.</p> <p>This bit indicates whether the xHC supports ESIT Payloads greater than 48K bytes. When this bit is '1', ESIT Payloads greater than 48K bytes are supported. When this bit is '0', ESIT Payloads greater than 48K bytes are not supported.</p>                                                                                                                                                                                                                                                                                              |
| 3              | R          | 0x1         | <p>CTC</p> <p>Compliance Transition Capability.</p> <p>This bit indicates whether the xHC USB3 Root Hub ports support the <i>Compliance Transition Enabled</i> (CTE) flag. When this bit is '1', USB3 Root Hub port state machine transitions to the Compliance substate shall be explicitly enabled software. When this bit is '0', USB3 Root Hub port state machine transitions to the Compliance substate are automatically enabled.</p>                                                                                                                                                    |
| 2              | R          | 0x1         | <p>FSC</p> <p>Force Save Context Capability.</p> <p>This bit indicates whether the xHC supports the <i>Force Save Context Capability</i>. When this bit is '1', the <i>Save State</i> operation shall save any cached Slot, Endpoint, Stream or other Context information to memory.</p>                                                                                                                                                                                                                                                                                                       |
| 1              | R          | 0x1         | <p>CMC</p> <p>Configure Endpoint Command Max Exit Latency Too Large Capability.</p> <p>This bit indicates whether a <i>Configure Endpoint Command</i> is capable of generating a <i>Max Exit Latency Too Large Capability Error</i>. When this bit is '1', a <i>Max Exit Latency Too Large Capability Error</i> may be returned by a <i>Configure Endpoint Command</i>. When this bit is '0', a <i>Max Exit Latency Too Large Capability Error</i> shall not be returned by a <i>Configure Endpoint Command</i>. This capability is enabled by the <i>CME</i> flag in the USBCMD register.</p> |
| 0              | R          | 0x1         | <p>U3C</p> <p>U3 Entry Capability.</p> <p>This bit indicates whether the xHC Root Hub ports</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

| Offset: 0x001C |            |             | Register Name: HCCPARAMS2                                                                                                                              |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                            |
|                |            |             | support port Suspend Complete notification. When this bit is '1', <i>PLC</i> shall be asserted on any transition of <i>PLS</i> to the <i>U3</i> State. |

#### 8.11.5.9 0x0020 xHC USB Command Register (Default Value:0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: HCUSBCMD                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                   |
| 31:14          | /          | /           | /                                                                                                                                                                                                                                                                                                                                             |
| 13             | R/W        | 0x0         | CME<br>CEM Enable<br>When set to '1', a <i>Max Exit Latency Too Large Capability Error</i> may be returned by a <i>Configure Endpoint Command</i> . When cleared to '0', a <i>Max Exit Latency Too Large Capability Error</i> shall not be returned by a <i>Configure Endpoint Command</i> . This bit is <i>Reserved</i> if <i>CMC</i> = '0'. |
| 12             | R/W        | 0x0         | SPE<br>Stopped - Short Packet Enable<br>When set to '1', the xHC may generate a <i>Stopped - Short Packet Completion Code</i> . This bit is <i>Reserved</i> if <i>CMC</i> = '0'.                                                                                                                                                              |
| 11             | R/W        | 0x0         | EU3S<br>Enable U3 MFINDEX Stop<br>When set to '1', the xHC may stop the MFINDEX counting action if all Root Hub ports are in the U3, Disconnected, Disabled, or Powered-off state. When cleared to '0' the xHC may stop the MFINDEX counting action if all Root Hub ports are in the Disconnected, Disabled, or Powered-off state.            |
| 10             | R/W        | 0x0         | EWE<br>Enable Wrap Event<br>When set to '1', the xHC shall generate a MFINDEX (Micro-Frame Index) Wrap Event every time the MFINDEX register transitions from 0x03FFF to 0. When cleared to '0' no MFINDEX Wrap Events are generated.                                                                                                         |
| 9              | R/W        | 0x0         | CRS<br>Controller Restore State<br>When set to '1', and <i>HCHalted</i> ( <i>HCH</i> ) = '1', then the xHC shall perform a Restore State operation and                                                                                                                                                                                        |

| Offset: 0x0020 |            |             | Register Name: HCUSBCMD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                |            |             | <p>restore its internal state. When set to '1' and Run/Stop (R/S) = '1' or HCHalted (HCH) = '0', or when cleared to '0', no Restore State operation shall be performed. This flag always returns '0' when read. Refer to the Restore State Status (RSS) flag in the HCUSBSTS register for information on Restore State completion.</p> <p>Note that undefined behavior may occur if a Restore State operation is initiated while Save State Status (SSS) = '1'.</p>                                                                                                                                                                                                                                                                                                                |
| 8              | R/W        | 0x0         | <p>CSS<br/>Controller Save State</p> <p>When written by software with '1' and <i>HCHalted</i> (HCH) = '1', then the xHC shall save any internal state (that may be restored by a subsequent Restore State operation) and if <i>FSC</i> = '1' any cached Slot, Endpoint, Stream, or other Context information (so that software may save it). When written by software with '1' and <i>HCHalted</i> (HCH) = '0', or written with '0', no Save State operation shall be performed. This flag always returns '0' when read. Refer to the <i>Save State Status</i> (SSS) flag in the USBSTS register for information on Save State completion.</p> <p>Note that undefined behavior may occur if a Save State operation is initiated while <i>Restore State Status</i> (RSS) = '1'.</p> |
| 7:4            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 3              | R/W        | 0x0         | <p>HSEE<br/>Host System Error Enable</p> <p>When this bit is a '1', and the HSE bit in the HCUSBSTS register is a '1', the xHC shall assert out-of-band error signaling to the host.</p> <p>The signaling is acknowledged by software clearing the HSE bit.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 2              | R/W        | 0x0         | <p>INTE<br/>Interrupter Enable</p> <p>This bit provides system software with a means of enabling or disabling the host system interrupts generated by Interrupters. When this bit is a '1', then Interrupter host system interrupt generation is allowed, e.g. the xHC shall issue an interrupt at the</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

| Offset: 0x0020 |            |             | Register Name: HCUSBCMD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                |            |             | next interrupt threshold if the host system interrupt mechanism (e.g. MSI, MSI-X, etc.) is enabled. The interrupt is acknowledged by a host system interrupt specific mechanism.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 1              | R/W        | 0x0         | <p>HCRST<br/>Host Controller Reset<br/>This control bit is used by software to reset the host controller. The effects of this bit on the xHC and the Root Hub registers are similar to a Chip Hardware Reset.</p> <p>When software writes a '1' to this bit, the Host Controller resets its internal pipelines, timers, counters, state machines, etc. to their initial value. Any transaction currently in progress on the USB is immediately terminated. A USB reset shall not be driven on USB2 downstream ports; however, a Hot or Warm Reset shall be initiated on USB3 Root Hub downstream ports.</p> <p>All operational registers, including port registers and port state machines are set to their initial values. Software shall reinitialize the host controller in order to return the host controller to an operational state. This bit is cleared to '0' by the Host Controller when the reset process is complete. Software cannot terminate the reset process early by writing a '0' to this bit and shall not write any xHC Operational or Runtime registers while HCRST is '1'. Note, the completion of the xHC reset process is not gated by the Root Hub port reset process.</p> <p>Software shall not set this bit to '1' when the HCHalted (HCH) bit in the USBSTS register is a '0'. Attempting to reset an actively running host controller may result in undefined behavior.</p> |
| 0              | R/W        | 0x0         | <p>RS<br/>Run/Stop<br/>0x1: Run<br/>0x0: Stop</p> <p>When set to '1' the xHC proceeds with execution of the schedule. The xHC continues execution as long as this bit is set to a '1'. When this bit is cleared to '0', the xHC completes any current or queued</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

| Offset: 0x0020 |            |             | Register Name: HCUSBCMD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                |            |             | <p>commands or TDs, and any USB transactions associated with them, then halts.</p> <p>The xHC shall halt within 16ms, after software clears the Run/Stop bit if the above conditions have been met.</p> <p>The HCHalted (HCH) bit in the HCUSBSTS register indicates when the xHC has finished its pending pipelined transactions and has entered the stopped state. Software shall not write a '1' to this flag unless the xHC is in the Halted state (i.e. HCH in the USBSTS register is '1'). Doing so may yield undefined results.</p> <p>Writing a '0' to this flag when the xHC is in the Running state (i.e. HCH='0') and any Event Rings are in the Event Ring Full state may yield undefined results.</p> |

#### 8.11.5.10 0x0024 xHC USB Status Register (Default Value:0x0000\_0001)

| Offset: 0x0024 |            |             | Register Name: HCUSBSTS                                                                                                                                                                                                                                                                                                                                                        |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                    |
| 31:13          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                              |
| 12             | R          | 0x0         | <p>HCE<br/>Host Controller Error</p> <p>This flag shall be set to indicate that an internal error condition has been detected which requires software to reset and reinitialize the xHC.</p>                                                                                                                                                                                   |
| 11             | R          | 0x0         | <p>CNR<br/>Controller Not Ready</p> <p>Software shall not write any Doorbell or Operational register of the xHC, other than the HCUSBSTS register, until CNR = '0'. This flag is set by the xHC after a Chip Hardware Reset and cleared when the xHC is ready to begin accepting register writes. This flag shall remain cleared ('0') until the next Chip Hardware Reset.</p> |
| 10             | R/W1C      | 0x0         | <p>SRE<br/>Save/Restore Error</p> <p>If an error occurs during a Save or Restore operation this bit shall be set to '1'. This bit shall be cleared to '0' when a Save or Restore operation is initiated or when written with '1'.</p>                                                                                                                                          |

| Offset: 0x0024 |            |             | Register Name: HCUSBSTS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                |            |             | <i>Note: This bit can be cleared by software writing '1'.</i>                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 9              | R          | 0x0         | RSS<br>Restore State Status<br>When the Controller Restore State (CRS) flag in the HCUSBCMD register is written with '1' this bit shall be set to '1' and remain 1 while the xHC restores its internal state. When the Restore State operation is complete, this bit shall be cleared to '0'.                                                                                                                                                                                                                               |
| 8              | R          | 0x0         | SSS<br>Save State Status<br>When the Controller Save State (CSS) flag in the HCUSBCMD register is written with '1' this bit shall be set to '1' and remain 1 while the xHC saves its internal state. When the Save State operation is complete, this bit shall be cleared to '0'.                                                                                                                                                                                                                                           |
| 7:5            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 4              | R/W1C      | 0x0         | PCD<br>Port Change Detect<br>The xHC sets this bit to a '1' when any port has a change bit transition from a '0' to a '1'.<br>This bit is allowed to be maintained in the Aux Power well. Alternatively, it is also acceptable that on a D3 to D0 transition of the xHC, this bit is loaded with the OR of all of the PORTSC change bits.<br>This bit provides system software an efficient means of determining if there has been Root Hub port activity.<br><i>Note: This bit can be cleared by software writing '1'.</i> |
| 3              | R/W1C      | 0x0         | EINT<br>Event Interrupt<br>The xHC sets this bit to '1' when the Interrupt Pending (IP) bit of any Interrupter transitions from '0' to '1'.<br>Software that uses EINT shall clear it prior to clearing any IP flags. A race condition may occur if software clears the IP flags then clears the EINT flag, and between the operations another IP '0' to '1' transition occurs. In this case the new IP transition shall be lost.<br><i>Note: This bit can be cleared by software writing '1'.</i>                          |
| 2              | R/W1C      | 0x0         | HSE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

| Offset: 0x0024 |            |             | Register Name: HCUSBSTS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                |            |             | <p>Host System Error<br/>The xHC sets this bit to '1' when a serious error is detected, either internal to the xHC or during a host system access involving the xHC module. When this error occurs, the xHC clears the Run/Stop (R/S) bit in the USBCMD register to prevent further execution of the scheduled TDs. If the HSEE bit in the HCUSBCMD register is a '1', the xHC shall also assert out-of-band error signaling to the host.</p> <p><b>Note:</b> This bit can be cleared by software writing '1'.</p> |
| 1              | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 0              | R          | 0x1         | <p>HCH<br/>HC Halted<br/>This bit is a '0' whenever the Run/Stop (R/S) bit is a '1'. The xHC sets this bit to '1' after it has stopped executing as a result of the Run/Stop (R/S) bit being cleared to '0', either by software or by the xHC hardware (e.g. internal error).<br/>If this bit is '1', then SOFs, microSOFs, or Isochronous Timestamp Packets (ITP) shall not be generated by the xHC, and any received Transaction Packet shall be dropped.</p>                                                    |

#### 8.11.5.11 0x0028 xHC Page Size Register (Default Value:0x0000\_0001)

| Offset: 0x0028 |            |             | Register Name: HCPAGESIZE                                                                                                                                                                                                                            |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                          |
| 31:16          | /          | /           | /                                                                                                                                                                                                                                                    |
| 15:0           | R          | 0x0001      | <p>PageSize<br/>Page Size<br/>This field defines the page size supported by the xHC implementation. This xHC supports a page size of <math>2^{(n+12)}</math> if bit n is Set. For example, if bit 0 is Set, the xHC supports 4k byte page sizes.</p> |

#### 8.11.5.12 0x0034 xHC Device Notification Control Register (Default Value:0x0000\_0000)

| Offset: 0x0034 |            |             | Register Name: HCDNCTRL |
|----------------|------------|-------------|-------------------------|
| Bit            | Read/Write | Default/Hex | Description             |
| 31:16          | /          | /           | /                       |

| Offset: 0x0034 |            |             | Register Name: HCDNCTRL                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 15:0           | R/W        | 0x0000      | <p>NE</p> <p>Notification Enable (N0-N15)</p> <p>When a Notification Enable bit is set, a Device Notification Event shall be generated when a Device Notification Transaction Packet is received with the matching value in the Notification Type field. For example, setting N1 to '1' enables Device Notification Event generation if a Device Notification TP is received with its Notification Type field set to '1' (FUNCTION_WAKE), etc.</p> |

#### 8.11.5.13 0x0038 xHC Command Ring Control Low Register (Default Value:0x0000\_0000)

| Offset: 0x0038 |            |             | Register Name: HCCRCLR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 31:6           | R/W        | 0x00        | <p>CRPL</p> <p>Command Ring Pointer Low</p> <p>This field defines bit [31:6] of the initial value of the 64-bit Command Ring Dequeue Pointer.</p> <p>Writes to this field are ignored when Command Ring Running (CRR) = '1'.</p> <p>If the CRCR is written while the Command Ring is stopped (CCR = '0'), the value of this field shall be used to fetch the first Command TRB the next time the Host Controller Doorbell register is written with the DB Reason field set to Host Controller Command.</p> <p>If the CRCR is not written while the Command Ring is stopped (CCR = '0') then the Command Ring shall begin fetching Command TRBs at the current value of the internal xHC Command Ring Dequeue Pointer.</p> <p>Reading this field always returns '0'.</p> <p><b>Note: If a system is incapable of issuing Qword accesses, then writes to the 64-bit address fields shall be performed using 2 Dword accesses; low Dword-first, high-Dword second.</b></p> |
| 5:4            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 3              | R          | 0x0         | <p>CRR</p> <p>Command Ring Running</p> <p>This flag is set to '1' if the Run/Stop (R/S) bit is '1' and the Host Controller Doorbell register is written with</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

| Offset: 0x0038 |            |             | Register Name: HCCRCLR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                |            |             | the DB Reason field set to Host Controller Command. It is cleared to '0' when the Command Ring is "stopped" after writing a '1' to the Command Stop (CS) or Command Abort (CA) flags, or if the R/S bit is cleared to '0'.                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 2              | R/W1S      | 0x0         | <p>CA<br/>Command Abort</p> <p>Writing a '1' to this bit shall immediately terminate the currently executing command, stop the Command Ring, and generate a Command Completion Event with the Completion Code set to Command Ring Stopped.</p> <p>The next write to the Host Controller Doorbell with DB Reason field set to Host Controller Command shall restart the Command Ring operation.</p> <p>Writes to this flag are ignored by the xHC if Command Ring Running (CRR) = '0'.</p> <p>Reading this bit always returns '0'.</p>                                                                                                                |
| 1              | R/W1S      | 0x0         | <p>CS<br/>Command Stop</p> <p>Writing a '1' to this bit shall stop the operation of the Command Ring after the completion of the currently executing command, and generate a Command Completion Event with the Completion Code set to Command Ring Stopped and the Command TRB Pointer set to the current value of the Command Ring Dequeue Pointer.</p> <p>The next write to the Host Controller Doorbell with DB Reason field set to Host Controller Command shall restart the Command Ring operation.</p> <p>Writes to this flag are ignored by the xHC if Command Ring Running (CRR) = '0'.</p> <p>Reading this bit shall always return '0'.</p> |
| 0              | R/W        | 0x0         | <p>RSC<br/>Ring Cycle State</p> <p>This bit identifies the value of the xHC Consumer Cycle State (CCS) flag for the TRB referenced by the Command Ring Pointer.</p> <p>Writes to this flag are ignored if Command Ring Running (CRR) is '1'.</p> <p>If the HCCRCL*R is written while the Command Ring is</p>                                                                                                                                                                                                                                                                                                                                         |

| Offset: 0x0038 |            |             | Register Name: HCCRCLR                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                |            |             | <p>stopped (CRR = '0'), then the value of this flag shall be used to fetch the first Command TRB the next time the Host Controller Doorbell register is written with the DB Reason field set to Host Controller Command.</p> <p>If the HCCRC*R is not written while the Command Ring is stopped (CRR = '0'), then the Command Ring shall begin fetching Command TRBs using the current value of the internal Command Ring CCS flag.</p> <p>Reading this flag always returns '0'.</p> |

#### 8.11.5.14 0x003C xHC Command Ring Control High Register (Default Value:0x0000\_0000)

| Offset: 0x003C |            |             | Register Name: HCCRCHR                                                                                                                       |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                  |
| 31:0           | R/W        | 0x00        | <p>CRPH<br/>Command Ring Pointer High<br/>This field defines bit[63:32] of the initial value of the 64-bit Command Ring Dequeue Pointer.</p> |

#### 8.11.5.15 0x0050 xHC Device Context Base Address Array Pointer Low Register (Default Value:0x0000\_0000)

| Offset: 0x0050 |            |             | Register Name: HCDCBAAPLR                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 31:6           | R/W        | 0x00        | <p>DCBAAPL<br/>Device Context Base Address Array Pointer Low<br/>This field defines bit [31:6] of the 64-bit base address of Device Context Pointer Array. A table of address pointers that reference Device Context structures for the device attached to the host.</p> <p><b>Note:</b> If a system is incapable of issuing Qword accesses, then writes to the 64-bit address fields shall be performed using 2 Dword accesses; low Dword-first, high-Dword second.</p> |
| 5:0            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

## 8.11.5.16 0x0054 xHC Device Context Base Address Array Pointer High Register (Default

Value:0x0000\_0000)

| Offset: 0x0054 |            |             | Register Name: HCDCBAAPHR                                                                                                                              |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                            |
| 31:0           | R/W        | 0x00        | DCBAAPH<br>Device Context Base Address Array Pointer High<br>This field defines bit[63:32] of the 64-bit base address of Device Context Pointer Array. |

## 8.11.5.17 0x0058 xHC Configure Register (Default Value:0x0000\_0000)

| Offset: 0x0058 |            |             | Register Name: HCONFIG                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 31:10          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 9              | R/W        | 0x0         | CIE<br>Configuration Information Enable<br>When set to '1', the software shall initialize the <i>Configuration Value</i> , <i>Interface Number</i> , and <i>Alternate Setting</i> fields in the Input Control Context when it is associated with a Configure Endpoint Command. When this bit is '0', the extended Input Control Context fields are not supported.                                                                                                                                    |
| 8              | R/W        | 0x0         | U3E<br>U3 Entry Enable<br>When set to '1', the xHC shall assert the <i>PLC</i> flag ('1') when a Root Hub port transitions to the U3 State.                                                                                                                                                                                                                                                                                                                                                          |
| 7:0            | R/W        | 0x00        | MaxSlotsEn<br>Max Device Slots Enabled<br>This field specifies the maximum number of enabled Device Slots. Valid values are in the range of 0 to MaxSlots. Enabled Devices Slots are allocated contiguously. e.g. A value of 16 specifies that Device Slots 1 to 16 are active.<br>A value of '0' disables all Device Slots. A disabled Device Slot shall not respond to Doorbell Register references.<br>This field shall not be modified by software if the xHC is running (Run/Stop (R/S) = '1'). |

## 8.11.5.18 0x0420 xHC Port1 Status and Control Register (USB2 Protocol) (Default Value:0x0000\_02A0)

| Offset: 0x0420 |            |             | Register Name: HCPORT1SC                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 31             | R/W        | 0x0         | <p>WPR<br/>Warm Port Reset<br/>When software writes a '1' to this bit, the Warm Reset sequence as defined in the USB3 Specification is initiated and the PR flag is set to '1'. Once initiated, the PR, PRC, and WRC flags shall reflect the progress of the Warm Reset sequence. This flag shall always return '0' when read.</p> <p>This flag only applies to USB3 protocol ports. For USB2 protocol ports it shall be reserved.</p> |
| 30             | R          | 0x0         | <p>DR<br/>Device Removable<br/>This flag indicates if this port has a removable device attached.<br/>0: Device is removable<br/>1: Device is non-removable</p>                                                                                                                                                                                                                                                                         |
| 29:28          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 27             | R/W        | 0x0         | <p>WOE<br/>Wake on Over-Current Enable<br/>Writing this bit to a '1' enables the port to be sensitive to over-current conditions as system wake-up events.</p>                                                                                                                                                                                                                                                                         |
| 26             | R/W        | 0x0         | <p>WDE<br/>Wake on Disconnect Enable<br/>Writing this bit to a '1' enables the port to be sensitive to device disconnects as system wake-up events.</p>                                                                                                                                                                                                                                                                                |
| 25             | R/W        | 0x0         | <p>WCE<br/>Wake on Connect Enable<br/>Writing this bit to a '1' enables the port to be sensitive to device connects as system wake-up events.</p>                                                                                                                                                                                                                                                                                      |
| 24             | R          | 0x0         | <p>CAS<br/>Cold Attach Status<br/>This bit is set when Far-end Receiver Terminations were detected in the Disconnected state and the Root Hub Port State Machine was unable advance to the Enabled state.<br/>Software shall clear this bit by writing a '1' to WPR or</p>                                                                                                                                                             |

| Offset: 0x0420           |                                                                                                                                                         |             | Register Name: HCPORT1SC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |            |           |              |                                |                          |                                                   |              |                                                   |                      |                                                     |          |                                                     |          |                                               |          |                                            |                       |                                                                                                                                                         |                 |                                                            |
|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-----------|--------------|--------------------------------|--------------------------|---------------------------------------------------|--------------|---------------------------------------------------|----------------------|-----------------------------------------------------|----------|-----------------------------------------------------|----------|-----------------------------------------------|----------|--------------------------------------------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------------------------------------------------------|
| Bit                      | Read/Write                                                                                                                                              | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |            |           |              |                                |                          |                                                   |              |                                                   |                      |                                                     |          |                                                     |          |                                               |          |                                            |                       |                                                                                                                                                         |                 |                                                            |
|                          |                                                                                                                                                         |             | the xHC shall clear this bit if CCS transitions to '1'. This flag is '0' if PP is '0' or for USB2 protocol ports.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |            |           |              |                                |                          |                                                   |              |                                                   |                      |                                                     |          |                                                     |          |                                               |          |                                            |                       |                                                                                                                                                         |                 |                                                            |
| 23                       | R/W1C                                                                                                                                                   | 0x0         | <p>CEC<br/>Port Config Error Change<br/>This flag indicates that the port failed to configure its link partner.<br/>0: No Change<br/>1: Port Config Error Detected<br/>Software shall clear this bit by writing a '1' to it.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |            |           |              |                                |                          |                                                   |              |                                                   |                      |                                                     |          |                                                     |          |                                               |          |                                            |                       |                                                                                                                                                         |                 |                                                            |
| 22                       | R/W1C                                                                                                                                                   | 0x0         | <p>PLC<br/>Port Link State Change<br/>This flag is set to '1' due to the following PLS transitions:</p> <table border="1"> <thead> <tr> <th>Transition</th><th>Condition</th></tr> </thead> <tbody> <tr> <td>U3 -&gt; Resume</td><td>Wakeup signaling from a device</td></tr> <tr> <td>Resume -&gt; Recovery -&gt; U0</td><td>Device Resume complete (USB3 protocol ports only)</td></tr> <tr> <td>Resume -&gt; U0</td><td>Device Resume complete (USB2 protocol ports only)</td></tr> <tr> <td>U3 -&gt; Recovery -&gt; U0</td><td>Software Resume complete (USB3 protocol ports only)</td></tr> <tr> <td>U3 -&gt; U0</td><td>Software Resume complete (USB2 protocol ports only)</td></tr> <tr> <td>U2 -&gt; U0</td><td>L1 Resume complete (USB2 protocol ports only)</td></tr> <tr> <td>U0 -&gt; U0</td><td>L1 Entry Reject (USB2 protocol ports only)</td></tr> <tr> <td>Any state -&gt; Inactive</td><td>Error (USB3 protocol ports only). Note: PLC is asserted only if there is an SS.Inactive.Disconnect.Detect to SS.Inactive.Quiet transition in the LTSSM.</td></tr> <tr> <td>Any State -&gt; U3</td><td>U3 Entry complete. Note: PLC is asserted only if U3E = '1'</td></tr> </tbody> </table> <p>Note that this flag shall not be set if the PLS</p> | Transition | Condition | U3 -> Resume | Wakeup signaling from a device | Resume -> Recovery -> U0 | Device Resume complete (USB3 protocol ports only) | Resume -> U0 | Device Resume complete (USB2 protocol ports only) | U3 -> Recovery -> U0 | Software Resume complete (USB3 protocol ports only) | U3 -> U0 | Software Resume complete (USB2 protocol ports only) | U2 -> U0 | L1 Resume complete (USB2 protocol ports only) | U0 -> U0 | L1 Entry Reject (USB2 protocol ports only) | Any state -> Inactive | Error (USB3 protocol ports only). Note: PLC is asserted only if there is an SS.Inactive.Disconnect.Detect to SS.Inactive.Quiet transition in the LTSSM. | Any State -> U3 | U3 Entry complete. Note: PLC is asserted only if U3E = '1' |
| Transition               | Condition                                                                                                                                               |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |            |           |              |                                |                          |                                                   |              |                                                   |                      |                                                     |          |                                                     |          |                                               |          |                                            |                       |                                                                                                                                                         |                 |                                                            |
| U3 -> Resume             | Wakeup signaling from a device                                                                                                                          |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |            |           |              |                                |                          |                                                   |              |                                                   |                      |                                                     |          |                                                     |          |                                               |          |                                            |                       |                                                                                                                                                         |                 |                                                            |
| Resume -> Recovery -> U0 | Device Resume complete (USB3 protocol ports only)                                                                                                       |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |            |           |              |                                |                          |                                                   |              |                                                   |                      |                                                     |          |                                                     |          |                                               |          |                                            |                       |                                                                                                                                                         |                 |                                                            |
| Resume -> U0             | Device Resume complete (USB2 protocol ports only)                                                                                                       |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |            |           |              |                                |                          |                                                   |              |                                                   |                      |                                                     |          |                                                     |          |                                               |          |                                            |                       |                                                                                                                                                         |                 |                                                            |
| U3 -> Recovery -> U0     | Software Resume complete (USB3 protocol ports only)                                                                                                     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |            |           |              |                                |                          |                                                   |              |                                                   |                      |                                                     |          |                                                     |          |                                               |          |                                            |                       |                                                                                                                                                         |                 |                                                            |
| U3 -> U0                 | Software Resume complete (USB2 protocol ports only)                                                                                                     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |            |           |              |                                |                          |                                                   |              |                                                   |                      |                                                     |          |                                                     |          |                                               |          |                                            |                       |                                                                                                                                                         |                 |                                                            |
| U2 -> U0                 | L1 Resume complete (USB2 protocol ports only)                                                                                                           |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |            |           |              |                                |                          |                                                   |              |                                                   |                      |                                                     |          |                                                     |          |                                               |          |                                            |                       |                                                                                                                                                         |                 |                                                            |
| U0 -> U0                 | L1 Entry Reject (USB2 protocol ports only)                                                                                                              |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |            |           |              |                                |                          |                                                   |              |                                                   |                      |                                                     |          |                                                     |          |                                               |          |                                            |                       |                                                                                                                                                         |                 |                                                            |
| Any state -> Inactive    | Error (USB3 protocol ports only). Note: PLC is asserted only if there is an SS.Inactive.Disconnect.Detect to SS.Inactive.Quiet transition in the LTSSM. |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |            |           |              |                                |                          |                                                   |              |                                                   |                      |                                                     |          |                                                     |          |                                               |          |                                            |                       |                                                                                                                                                         |                 |                                                            |
| Any State -> U3          | U3 Entry complete. Note: PLC is asserted only if U3E = '1'                                                                                              |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |            |           |              |                                |                          |                                                   |              |                                                   |                      |                                                     |          |                                                     |          |                                               |          |                                            |                       |                                                                                                                                                         |                 |                                                            |

| Offset: 0x0420 |            |             | Register Name: HCPORT1SC                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                |            |             | transition was due to software setting PP to '0'.<br>'0' = No change. '1' = Link Status Changed. Software shall clear this bit by writing a '1' to it.                                                                                                                                                                                                                                                                                                            |
| 21             | R/W1C      | 0x0         | PRC<br>Port Reset Change<br>This flag is set to '1' due a '1' to '0' transition of Port Reset (PR). e.g. when any reset processing (Warm or Hot) on this port is complete. Note that this flag shall not be set to '1' if the reset processing was forced to terminate due to software clearing PP or PED to '0'.<br>'0' = No change. '1' = Reset complete.<br>Software shall clear this bit by writing a '1' to it.                                              |
| 20             | R/W1C      | 0x0         | OCC<br>Over-Current Change<br>This bit shall be set to a '1' when there is a '0' to '1' or '1' to '0' transition of Over-Current Active (OCA).<br>Software shall clear this bit by writing a '1' to it.                                                                                                                                                                                                                                                           |
| 19             | R/W1C      | 0x0         | WRC<br>Warm Port Reset Change<br>This bit is set when Warm Reset processing on this port completes.<br>'0' = No change.<br>'1' = Warm Reset complete.<br>Note that this flag shall not be set to '1' if the Warm Reset processing was forced to terminate due to software clearing PP or PED to '0'. Software shall clear this bit by writing a '1' to it.<br>This bit only applies to USB3 protocol ports. For USB2 protocol ports it shall be Reserved.         |
| 18             | R/W1C      | 0x0         | PEC<br>Port Enabled/Disabled Change<br>'1' = change in PED. '0' = No change.<br>Note that this flag shall not be set if the PED transition was due to software setting PP to '0'.<br>Software shall clear this bit by writing a '1' to it.<br>For a USB2 protocol port, this bit shall be set to '1' only when the port is disabled due to the appropriate conditions existing at the EOF2 point<br>For a USB3 protocol port, this bit shall never be set to '1'. |
| 17             | R/W1C      | 0x0         | CSC                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

| Offset: 0x0420 |            |             | Register Name: HCPORT1SC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                |            |             | <p>Connect Status Change<br/>           ‘1’ = Change in CCS. ‘0’ = No change.<br/>           This flag indicates a change has occurred in the port’s Current Connect Status (CCS) or Cold Attach Status (CAS) bits. Note that this flag shall not be set if the CCS transition was due to software setting PP to ‘0’, or the CAS transition was due to software setting WPR to ‘1’.</p> <p>The xHC sets this bit to ‘1’ for all changes to the port device connect status, even if system software has not cleared an existing Connect Status Change. For example, the insertion status changes twice before system software has cleared the changed condition, root hub hardware will be “setting” an already-set bit (i.e., the bit will remain ‘1’). Software shall clear this bit by writing a ‘1’ to it.</p> |
| 16             | R/W        | 0x0         | <p>LWS<br/>           Port Link State Write Strobe<br/>           When this bit is set to ‘1’ on a write reference to this register, this flag enables writes to the PLS field.<br/>           When ‘0’, write data in PLS field is ignored. Reads to this bit return ‘0’.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 15:14          | R/W        | 0x0         | <p>PIC<br/>           Port Indicator Control<br/>           Writing to these bits has no effect if the Port Indicators (PIND) bit in the HCCPARAMS register is a ‘0’. If PIND bit is a ‘1’, then the bit encodings are:<br/>           0: Port indicators are off<br/>           1: Amber<br/>           2: Green<br/>           3: Undefined<br/>           This field is ‘0’ if PP is ‘0’.</p>                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 13:10          | R          | 0x0         | <p>PSPD<br/>           Port Speed<br/>           This field identifies the speed of the attached USB Device. This field is only relevant if a device is attached (CCS = ‘1’) in all other cases this field shall indicate <i>Undefined Speed</i>.<br/>           0: Undefined Speed<br/>           1-15: Protocol Speed ID (PSI)<br/>           1: Full-speed 12 MB/s</p>                                                                                                                                                                                                                                                                                                                                                                                                                                         |

| Offset: 0x0420 |            |             | Register Name: HCPORT1SC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                |            |             | <p>2: Low-speed 1.5 Mb/s<br/>     3: High-speed 480 Mb/s<br/>     4: SuperSpeed 5 Gb/s.<br/> <b>Note:</b> This field is invalid on a USB2 protocol port until after the port is reset.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 9              | R/W        | 0x1         | <p>PP<br/>     Port Power<br/>     This flag reflects a port's logical, power control state.<br/>     Because host controllers can implement different methods of port power switching, this flag may or may not represent whether (VBus) power is actually applied to the port. When PP equals a '0' the port is nonfunctional and shall not report attaches, detaches, or Port Link State (PLS) changes. However, the port shall report over-current conditions when PP = '0' if PPC = '0'. After modifying PP, software shall read PP and confirm that it is reached its target state before modifying it again, undefined behavior may occur if this procedure is not followed.</p> <p>0: This port is in the Powered-off state.<br/>     1: This port is not in the Powered-off state.<br/>     If the Port Power Control (PPC) flag in the HCCPARAMS register is '1', then xHC has port power control switches and this bit represents the current setting of the switch ('0' = off, '1' = on).<br/>     If the Port Power Control (PPC) flag in the HCCPARAMS register is '0', then xHC does not have port power control switches and each port is hard wired to power, and not affected by this bit.<br/>     When an over-current condition is detected on a powered port, the xHC shall transition the PP bit in each affected port from a '1' to '0' (removing power from the port).</p> |
| 8:5            | R/W        | 0x5         | <p>PLS<br/>     Port Link State<br/>     Default = RxDetect ('5'). This field is used to power manage the port and reflects its current link state.<br/>     When the port is in the Enabled state, system software may set the link U state by writing this field.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

| Offset: 0x0420 |            |             | Register Name: HCPORT1SC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                |            |             | <p>System software may also write this field to force a Disabled to Disconnected state transition of the port.</p> <p>Write value and Description:</p> <ul style="list-style-type: none"> <li>0: The link shall transition to a U0 state from any of the U states.</li> <li>2: USB2 protocol ports only. The link should transition to the U2 State.</li> <li>3: The link shall transition to a U3 state from any of the U states. This action selectively suspends the device connected to this port. While the Port Link State = U3, the hub does not propagate downstream-directed traffic to this port, but the hub shall respond to resume signaling from the port.</li> <li>5: USB3 protocol ports only. If the port is in the Disabled state (PLS = Disabled, PP = 1), then the link shall transition to a RxDetect state and the port shall transition to the Disconnected state, else ignored.</li> <li>10: USB3 protocol ports only. Shall enable a link transition to the Compliance state, i.e. <math>CTE = '1'</math>.</li> <li>1, 4, 6-9, 11-14: Ignored.</li> <li>15: USB2 protocol ports only. If the port is in the U3 state (PLS = U3), then the link shall remain in the U3 state and the port shall transition to the U3Exit sub-state, else ignored.</li> </ul> <p><b>Note:</b> The Port Link State Write Strobe (LWS) shall also be set to '1' to write this field.</p> <p><b>For USB2 protocol ports:</b> Writing a value of '2' to this field shall request LPM, asserting L1 signaling on the USB2 bus. Software may read this field to determine if the transition to the U2 state was successful. Writing a value of '0' shall de-assert L1 signaling on the USB. Writing a value of '1' shall have no effect. The U1 state shall never be reported by a USB2 protocol port.</p> <p>Read value and Meaning:</p> <ul style="list-style-type: none"> <li>0: Link is in the U0 State</li> </ul> |

| Offset: 0x0420 |            |             | Register Name: HCPORT1SC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                |            |             | <p>1: Link is in the U1 State<br/>         2: Link is in the U2 State<br/>         3: Link is in the U3 State (Device Suspended)<br/>         4: Link is in the Disabled State<br/>         5: Link is in the RxDetect State<br/>         6: Link is in the Inactive State<br/>         7: Link is in the Polling State<br/>         8: Link is in the Recovery State<br/>         9: Link is in the Hot Reset State<br/>         10: Link is in the Compliance Mode State<br/>         11: Link is in the Test Mode State<br/>         12-14: Reserved<br/>         15: Link is in the Resume State</p> <p>This field is undefined if PP = '0'.</p> <p><b>Note:</b> Transitions between different states are not reflected until the transition is complete.</p> |
| 4              | R/W1S      | 0x0         | <p>PR<br/>         Port Reset<br/>         '1' = Port Reset signaling is asserted. '0' = Port is not in Reset.</p> <p>When software writes a '1' to this bit (from a '0') the bus reset sequence is initiated; USB2 protocol ports shall execute the bus reset sequence as defined in the USB2 Spec. USB3 protocol ports shall execute the Hot Reset sequence as defined in the USB3 Spec. PR remains set until reset signaling is completed by the root hub.</p> <p>Note that software shall write a '1' to this flag to transition a USB2 port from the Polling state to the Enabled state.</p> <p>This flag is '0' if PP is '0'.</p>                                                                                                                           |
| 3              | R          | 0x0         | <p>OCA<br/>         Over-Current Active<br/>         '1' = This port currently has an over-current condition. '0' = This port does not have an over-current condition.</p> <p>This bit shall automatically transition from a '1' to a '0' when the over-current condition is removed.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 2              | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 1              | R/W1CS     | 0x0         | PED                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

| Offset: 0x0420 |            |             | Register Name: HCPORT1SC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                |            |             | <p>Port Enabled/Disabled<br/>Ports may only be enabled by the xHC. Software cannot enable a port by writing a '1' to this flag. A port may be disabled by software writing a '1' to this flag.</p> <p>This flag shall automatically be cleared to '0' by a disconnect event or other fault condition.</p> <p>Note that the bit status does not change until the port state actually changes. There may be a delay in disabling or enabling a port due to other host controller or bus events.</p> <p>When the port is disabled (PED = '0') downstream propagation of data is blocked on this port, except for reset.</p> <p>For USB2 protocol ports:<br/>When the port is in the Disabled state, software shall reset the port (PR = '1') to transition PED to '1' and the port to the Enabled state.</p> <p>For USB3 protocol ports:<br/>When the port is in the Polling state (after detecting an attach), the port shall automatically transition to the Enabled state and set PED to '1' upon the completion of successful link training.<br/>When the port is in the Disabled state, software shall write a '5' (RxDetect) to the PLS field to transition the port to the Disconnected state.<br/>PED shall automatically be cleared to '0' when PR is set to '1', and set to '1' when PR transitions from '1' to '0' after a successful reset. Refer to Port Reset (PR) bit for more information on how the PED bit is managed.<br/>Note that when software writes this bit to a '1', it shall also write a '0' to the PR bit.<br/>This flag is '0' if PP is '0'.</p> |
| 0              | R          | 0x0         | <p>CCS<br/>Current Connect Status<br/>'1' = A device is connected to the port. '0' = A device is not connected.</p> <p>This value reflects the current state of the port, and may not correspond directly to the event that caused the Connect Status Change (CSC) bit to be</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

| Offset: 0x0420 |            |             | Register Name: HCPORT1SC                      |
|----------------|------------|-------------|-----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                   |
|                |            |             | set to '1'.<br>This flag is '0' if PP is '0'. |

8.11.5.19 0x0424 xHC Port1 PM Status and Control Register (USB2 Protocol) (Default 0x0424  
 Value:0x0000\_0000)

| Offset: 0x0424 |                         |             | Register Name: HCPORT1PMSC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |       |           |     |                       |     |              |     |              |     |              |     |             |     |                   |         |          |     |                         |
|----------------|-------------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|-----------|-----|-----------------------|-----|--------------|-----|--------------|-----|--------------|-----|-------------|-----|-------------------|---------|----------|-----|-------------------------|
| Bit            | Read/Write              | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |           |     |                       |     |              |     |              |     |              |     |             |     |                   |         |          |     |                         |
| 31:28          | R/W                     | 0x0         | <p>PTC<br/>                 Port Test Control (Test Mode)<br/>                 When this field is '0', the port is NOT operating in a test mode. A non-zero value indicates that it is operating in test mode and the specific test mode is indicated by the specific value.<br/>                 A non-zero Port Test Control value is only valid to a port that is in the Powered-Off state (PLS = Disabled). If the port is not in this state, the xHC shall respond with the Port Test Control field set to Port Test Control Error.<br/>                 The encoding of the Test Mode bits for a USB2 protocol port are:</p> <table border="1"> <tr> <td>Value</td> <td>Test Mode</td> </tr> <tr> <td>0x0</td> <td>Test mode not enabled</td> </tr> <tr> <td>0x1</td> <td>Test J_STATE</td> </tr> <tr> <td>0x2</td> <td>Test K_STATE</td> </tr> <tr> <td>0x3</td> <td>Test SE0_NAK</td> </tr> <tr> <td>0x4</td> <td>Test Packet</td> </tr> <tr> <td>0x5</td> <td>Test FORCE_ENABLE</td> </tr> <tr> <td>0x6-0xE</td> <td>Reserved</td> </tr> <tr> <td>0xF</td> <td>Port Test Control Error</td> </tr> </table> <p>Refer to the sections 7.1.20 and 11.24.2.13 of the USB2 spec for more information on Test Modes.</p> | Value | Test Mode | 0x0 | Test mode not enabled | 0x1 | Test J_STATE | 0x2 | Test K_STATE | 0x3 | Test SE0_NAK | 0x4 | Test Packet | 0x5 | Test FORCE_ENABLE | 0x6-0xE | Reserved | 0xF | Port Test Control Error |
| Value          | Test Mode               |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |           |     |                       |     |              |     |              |     |              |     |             |     |                   |         |          |     |                         |
| 0x0            | Test mode not enabled   |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |           |     |                       |     |              |     |              |     |              |     |             |     |                   |         |          |     |                         |
| 0x1            | Test J_STATE            |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |           |     |                       |     |              |     |              |     |              |     |             |     |                   |         |          |     |                         |
| 0x2            | Test K_STATE            |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |           |     |                       |     |              |     |              |     |              |     |             |     |                   |         |          |     |                         |
| 0x3            | Test SE0_NAK            |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |           |     |                       |     |              |     |              |     |              |     |             |     |                   |         |          |     |                         |
| 0x4            | Test Packet             |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |           |     |                       |     |              |     |              |     |              |     |             |     |                   |         |          |     |                         |
| 0x5            | Test FORCE_ENABLE       |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |           |     |                       |     |              |     |              |     |              |     |             |     |                   |         |          |     |                         |
| 0x6-0xE        | Reserved                |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |           |     |                       |     |              |     |              |     |              |     |             |     |                   |         |          |     |                         |
| 0xF            | Port Test Control Error |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |           |     |                       |     |              |     |              |     |              |     |             |     |                   |         |          |     |                         |
| 27:17          | /                       | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       |           |     |                       |     |              |     |              |     |              |     |             |     |                   |         |          |     |                         |
| 16             | R/W                     | 0x0         | <p>HLE<br/>                 Hardware LPM Enable<br/>                 If this bit is set to '1', then hardware controlled LPM shall be enabled for this port.<br/> <b>Note: If the USB2 Hardware LMP Capability is not supported (HLC = '0') this field shall be Reserved.</b></p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       |           |     |                       |     |              |     |              |     |              |     |             |     |                   |         |          |     |                         |
| 15:8           | R/W                     | 0x0         | L1DS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |       |           |     |                       |     |              |     |              |     |              |     |             |     |                   |         |          |     |                         |

| Offset: 0x0424 |                                                                |             | Register Name: HCPORT1PMSC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |       |         |     |                                                    |     |                                                      |     |                                                            |     |                                                                |     |                        |         |          |
|----------------|----------------------------------------------------------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------|-----|----------------------------------------------------|-----|------------------------------------------------------|-----|------------------------------------------------------------|-----|----------------------------------------------------------------|-----|------------------------|---------|----------|
| Bit            | Read/Write                                                     | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |         |     |                                                    |     |                                                      |     |                                                            |     |                                                                |     |                        |         |          |
|                |                                                                |             | <p>L1 Device Slot<br/>System software sets this field to indicate the ID of the Device Slot associated with the device directly attached to the Root Hub port. A value of '0' indicates no device is present. The xHC uses this field to lookup information necessary to generate the LMP Token packet.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |       |         |     |                                                    |     |                                                      |     |                                                            |     |                                                                |     |                        |         |          |
| 7:4            | R/W                                                            | 0x0         | <p>BESL<br/>Best Effort Service Latency<br/>System software sets this field to indicate to the recipient device how long the xHC will drive resume if it (the xHC) initiates an exit from L1.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |       |         |     |                                                    |     |                                                      |     |                                                            |     |                                                                |     |                        |         |          |
| 3              | R/W                                                            | 0x0         | <p>RWE<br/>Remote Wake Enable<br/>System software sets this flag to enable or disable the device for remote wake from L1. The value of this flag shall temporarily (while in L1) override the current setting of the Remote Wake feature set by the standard Set/ClearFeature() commands defined in Universal Serial Bus Specification, revision 2.0, Chapter 9.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |       |         |     |                                                    |     |                                                      |     |                                                            |     |                                                                |     |                        |         |          |
| 2:0            | R                                                              | 0x0         | <p>L1S<br/>L1 Status<br/>This field is used by software to determine whether an L1-based suspend request (LMP transition) was successful, specifically:</p> <table border="1"> <thead> <tr> <th>Value</th><th>Meaning</th></tr> </thead> <tbody> <tr> <td>0x0</td><td>Invalid – This field shall be ignored by software.</td></tr> <tr> <td>0x1</td><td>Success – Port successfully transitioned to L1 (ACK)</td></tr> <tr> <td>0x2</td><td>Not Yet – Device is unable to enter L1 at this time (NYET)</td></tr> <tr> <td>0x3</td><td>Not Supported – Device does not support L1 transitions (STALL)</td></tr> <tr> <td>0x4</td><td>Timeout/Error – Device</td></tr> <tr> <td>0x5-0x7</td><td>Reserved</td></tr> </tbody> </table> <p>The value of this field is only valid when the port resides in the L0 or L1 state (PLS = '0' or '2').</p> | Value | Meaning | 0x0 | Invalid – This field shall be ignored by software. | 0x1 | Success – Port successfully transitioned to L1 (ACK) | 0x2 | Not Yet – Device is unable to enter L1 at this time (NYET) | 0x3 | Not Supported – Device does not support L1 transitions (STALL) | 0x4 | Timeout/Error – Device | 0x5-0x7 | Reserved |
| Value          | Meaning                                                        |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |         |     |                                                    |     |                                                      |     |                                                            |     |                                                                |     |                        |         |          |
| 0x0            | Invalid – This field shall be ignored by software.             |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |         |     |                                                    |     |                                                      |     |                                                            |     |                                                                |     |                        |         |          |
| 0x1            | Success – Port successfully transitioned to L1 (ACK)           |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |         |     |                                                    |     |                                                      |     |                                                            |     |                                                                |     |                        |         |          |
| 0x2            | Not Yet – Device is unable to enter L1 at this time (NYET)     |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |         |     |                                                    |     |                                                      |     |                                                            |     |                                                                |     |                        |         |          |
| 0x3            | Not Supported – Device does not support L1 transitions (STALL) |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |         |     |                                                    |     |                                                      |     |                                                            |     |                                                                |     |                        |         |          |
| 0x4            | Timeout/Error – Device                                         |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |         |     |                                                    |     |                                                      |     |                                                            |     |                                                                |     |                        |         |          |
| 0x5-0x7        | Reserved                                                       |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |         |     |                                                    |     |                                                      |     |                                                            |     |                                                                |     |                        |         |          |

## 8.11.5.20 0x0428 xHC Port1 Link Info Register (USB2 Protocol) (Default Value:0x0000\_0000)

| Offset: 0x0428 |            |             | Register Name: HCPORT1LI |
|----------------|------------|-------------|--------------------------|
| Bit            | Read/Write | Default/Hex | Description              |
| 31:0           | /          | /           | /                        |

## 8.11.5.21 0x0430 xHC Port2 Status and Control Register (USB3 Protocol) (Default Value:0x000002A0)

| Offset: 0x0430 |            |             | Register Name: HCPORT2SC                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 31             | R/W        | 0x0         | <p>WPR<br/>Warm Port Reset<br/>When software writes a '1' to this bit, the Warm Reset sequence as defined in the USB3 Specification is initiated and the PR flag is set to '1'. Once initiated, the PR, PRC, and WRC flags shall reflect the progress of the Warm Reset sequence. This flag shall always return '0' when read.</p> <p>This flag only applies to USB3 protocol ports. For USB2 protocol ports it shall be reserved.</p> |
| 30             | R          | 0x0         | <p>DR<br/>Device Removable<br/>This flag indicates if this port has a removable device attached.</p> <p>0: Device is removable<br/>1: Device is non-removable</p>                                                                                                                                                                                                                                                                      |
| 29:28          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 27             | R/W        | 0x0         | <p>WOE<br/>Wake on Over-Current Enable<br/>Writing this bit to a '1' enables the port to be sensitive to over-current conditions as system wake-up events.</p>                                                                                                                                                                                                                                                                         |
| 26             | R/W        | 0x0         | <p>WDE<br/>Wake on Disconnect Enable<br/>Writing this bit to a '1' enables the port to be sensitive to device disconnects as system wake-up events.</p>                                                                                                                                                                                                                                                                                |
| 25             | R/W        | 0x0         | <p>WCE<br/>Wake on Connect Enable<br/>Writing this bit to a '1' enables the port to be sensitive to device connects as system wake-up events.</p>                                                                                                                                                                                                                                                                                      |
| 24             | R          | 0x0         | CAS                                                                                                                                                                                                                                                                                                                                                                                                                                    |

| Offset: 0x0430           |                                                     |             | Register Name: HCPORT2SC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |            |           |              |                                |                          |                                                   |              |                                                   |                      |                                                     |          |                                                     |          |                                               |          |                                            |
|--------------------------|-----------------------------------------------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-----------|--------------|--------------------------------|--------------------------|---------------------------------------------------|--------------|---------------------------------------------------|----------------------|-----------------------------------------------------|----------|-----------------------------------------------------|----------|-----------------------------------------------|----------|--------------------------------------------|
| Bit                      | Read/Write                                          | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |            |           |              |                                |                          |                                                   |              |                                                   |                      |                                                     |          |                                                     |          |                                               |          |                                            |
|                          |                                                     |             | <p>Cold Attach Status<br/>                     This bit is set when Far-end Receiver Terminations were detected in the Disconnected state and the Root Hub Port State Machine was unable advance to the Enabled state.<br/>                     Software shall clear this bit by writing a '1' to WPR or the xHC shall clear this bit if CCS transitions to '1'.<br/>                     This flag is '0' if PP is '0' or for USB2 protocol ports.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |            |           |              |                                |                          |                                                   |              |                                                   |                      |                                                     |          |                                                     |          |                                               |          |                                            |
| 23                       | R/W                                                 | 0x0         | <p>CEC<br/>                     Port Config Error Change<br/>                     This flag indicates that the port failed to configure its link partner.<br/>                     0: No Change<br/>                     1: Port Config Error Detected<br/>                     Software shall clear this bit by writing a '1' to it.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |            |           |              |                                |                          |                                                   |              |                                                   |                      |                                                     |          |                                                     |          |                                               |          |                                            |
| 22                       | R/W                                                 | 0x0         | <p>PLC<br/>                     Port Link State Change<br/>                     This flag is set to '1' due to the following PLS transitions:</p> <table border="1"> <thead> <tr> <th>Transition</th><th>Condition</th></tr> </thead> <tbody> <tr> <td>U3 -&gt; Resume</td><td>Wakeup signaling from a device</td></tr> <tr> <td>Resume -&gt; Recovery -&gt; U0</td><td>Device Resume complete (USB3 protocol ports only)</td></tr> <tr> <td>Resume -&gt; U0</td><td>Device Resume complete (USB2 protocol ports only)</td></tr> <tr> <td>U3 -&gt; Recovery -&gt; U0</td><td>Software Resume complete (USB3 protocol ports only)</td></tr> <tr> <td>U3 -&gt; U0</td><td>Software Resume complete (USB2 protocol ports only)</td></tr> <tr> <td>U2 -&gt; U0</td><td>L1 Resume complete (USB2 protocol ports only)</td></tr> <tr> <td>U0 -&gt; U0</td><td>L1 Entry Reject (USB2 protocol ports only)</td></tr> </tbody> </table> | Transition | Condition | U3 -> Resume | Wakeup signaling from a device | Resume -> Recovery -> U0 | Device Resume complete (USB3 protocol ports only) | Resume -> U0 | Device Resume complete (USB2 protocol ports only) | U3 -> Recovery -> U0 | Software Resume complete (USB3 protocol ports only) | U3 -> U0 | Software Resume complete (USB2 protocol ports only) | U2 -> U0 | L1 Resume complete (USB2 protocol ports only) | U0 -> U0 | L1 Entry Reject (USB2 protocol ports only) |
| Transition               | Condition                                           |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |            |           |              |                                |                          |                                                   |              |                                                   |                      |                                                     |          |                                                     |          |                                               |          |                                            |
| U3 -> Resume             | Wakeup signaling from a device                      |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |            |           |              |                                |                          |                                                   |              |                                                   |                      |                                                     |          |                                                     |          |                                               |          |                                            |
| Resume -> Recovery -> U0 | Device Resume complete (USB3 protocol ports only)   |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |            |           |              |                                |                          |                                                   |              |                                                   |                      |                                                     |          |                                                     |          |                                               |          |                                            |
| Resume -> U0             | Device Resume complete (USB2 protocol ports only)   |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |            |           |              |                                |                          |                                                   |              |                                                   |                      |                                                     |          |                                                     |          |                                               |          |                                            |
| U3 -> Recovery -> U0     | Software Resume complete (USB3 protocol ports only) |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |            |           |              |                                |                          |                                                   |              |                                                   |                      |                                                     |          |                                                     |          |                                               |          |                                            |
| U3 -> U0                 | Software Resume complete (USB2 protocol ports only) |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |            |           |              |                                |                          |                                                   |              |                                                   |                      |                                                     |          |                                                     |          |                                               |          |                                            |
| U2 -> U0                 | L1 Resume complete (USB2 protocol ports only)       |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |            |           |              |                                |                          |                                                   |              |                                                   |                      |                                                     |          |                                                     |          |                                               |          |                                            |
| U0 -> U0                 | L1 Entry Reject (USB2 protocol ports only)          |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |            |           |              |                                |                          |                                                   |              |                                                   |                      |                                                     |          |                                                     |          |                                               |          |                                            |

| Offset: 0x0430                                                                                    |            |             | Register Name: HCPORT2SC                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                         |  |
|---------------------------------------------------------------------------------------------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Bit                                                                                               | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                         |  |
| 21                                                                                                | R/W1C      | 0x0         | Any state -> Inactive                                                                                                                                                                                                                                                                                                                                                                                                                                     | Error (USB3 protocol ports only). Note: PLC is asserted only if there is an SS.Inactive.Disconnect.Detect to SS.Inactive.Quiet transition in the LTSSM. |  |
|                                                                                                   |            |             | Any State -> U3                                                                                                                                                                                                                                                                                                                                                                                                                                           | U3 Entry complete. Note: PLC is asserted only if U3E = '1'                                                                                              |  |
| Note that this flag shall not be set if the PLS transition was due to software setting PP to '0'. |            |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                         |  |
| 21                                                                                                | R/W1C      | 0x0         | PRC<br>Port Reset Change<br>This flag is set to '1' due a '1' to '0' transition of Port Reset (PR). e.g. when any reset processing (Warm or Hot) on this port is complete. Note that this flag shall not be set to '1' if the reset processing was forced to terminate due to software clearing PP or PED to '0'. '0' = No change. '1' = Reset complete.<br>Software shall clear this bit by writing a '1' to it.                                         |                                                                                                                                                         |  |
| 20                                                                                                | R/W1C      | 0x0         | OCC<br>Over-Current Change<br>This bit shall be set to a '1' when there is a '0' to '1' or '1' to '0' transition of Over-current Active (OCA).<br>Software shall clear this bit by writing a '1' to it.                                                                                                                                                                                                                                                   |                                                                                                                                                         |  |
| 19                                                                                                | R/W1C      | 0x0         | WRC<br>Warm Port Reset Change<br>This bit is set when Warm Reset processing on this port completes.<br>'0' = No change.<br>'1' = Warm Reset complete.<br>Note that this flag shall not be set to '1' if the Warm Reset processing was forced to terminate due to software clearing PP or PED to '0'. Software shall clear this bit by writing a '1' to it.<br>This bit only applies to USB3 protocol ports. For USB2 protocol ports it shall be Reserved. |                                                                                                                                                         |  |
| 18                                                                                                | R/W1C      | 0x0         | PEC<br>Port Enabled/Disabled Change<br>Note that this flag shall not be set if the PED                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                         |  |

| Offset: 0x0430 |            |             | Register Name: HCPORT2SC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                |            |             | transition was due to software setting PP to '0'. Software shall clear this bit by writing a '1' to it. For a USB2 protocol port, this bit shall be set to '1' only when the port is disabled due to the appropriate conditions existing at the EOF2 point For a USB3 protocol port, this bit shall never be set to '1'.                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 17             | R/W1C      | 0x0         | CSC<br>Connect Status Change<br>This flag indicates a change has occurred in the port's Current Connect Status (CCS) or Cold Attach Status (CAS) bits. Note that this flag shall not be set if the CCS transition was due to software setting PP to '0', or the CAS transition was due to software setting WPR to '1'.<br>The xHC sets this bit to '1' for all changes to the port device connect status, even if system software has not cleared an existing Connect Status Change. For example, the insertion status changes twice before system software has cleared the changed condition, root hub hardware will be "setting" an already-set bit (i.e., the bit will remain '1'). Software shall clear this bit by writing a '1' to it. |
| 16             | R/W        | 0x0         | LWS<br>Port Link State Write Strobe<br>When this bit is set to '1' on a write reference to this register, this flag enables writes to the PLS field.<br>When '0', write data in PLS field is ignored. Reads to this bit return '0'.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 15:14          | R/W        | 0x0         | PIC<br>Port Indicator Control<br>Writing to these bits has no effect if the Port Indicators (PIND) bit in the HCCPARAMS register is a '0'. If PIND bit is a '1', then the bit encodings are:<br>0: Port indicators are off<br>1: Amber<br>2: Green<br>3: Undefined<br>This field is '0' if PP is '0'.                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 13:10          | R          | 0x0         | PSPD<br>Port Speed                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

| Offset: 0x0430 |            |             | Register Name: HCPORT2SC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                |            |             | <p>This field identifies the speed of the attached USB Device. This field is only relevant if a device is attached (CCS = '1') in all other cases this field shall indicate <i>Undefined Speed</i>.</p> <p>0: Undefined Speed<br/>     1-15: Protocol Speed ID (PSI)<br/>     1: Full-speed 12 MB/s<br/>     2: Low-speed 1.5 Mb/s<br/>     3: High-speed 480 Mb/s<br/>     4: SuperSpeed 5 Gb/s.</p> <p><b>Note: This field is invalid on a USB2 protocol port until after the port is reset.</b></p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 9              | R/W        | 0x1         | <p>PP<br/>     Port Power<br/>     This flag reflects a port's logical, power control state.<br/>     Because host controllers can implement different methods of port power switching, this flag may or may not represent whether (VBus) power is actually applied to the port. When PP equals a '0' the port is nonfunctional and shall not report attaches, detaches, or Port Link State (PLS) changes. However, the port shall report over-current conditions when PP = '0' if PPC = '0'. After modifying PP, software shall read PP and confirm that it is reached its target state before modifying it again, undefined behavior may occur if this procedure is not followed.</p> <p>0: This port is in the Powered-off state.<br/>     1: This port is not in the Powered-off state.<br/>     If the Port Power Control (PPC) flag in the HCCPARAMS register is '1', then xHC has port power control switches and this bit represents the current setting of the switch ('0' = off, '1' = on).<br/>     If the Port Power Control (PPC) flag in the HCCPARAMS register is '0', then xHC does not have port power control switches and each port is hard wired to power, and not affected by this bit.<br/>     When an over-current condition is detected on a powered port, the xHC shall transition the PP bit in each affected port from a '1' to '0' (removing power)</p> |

| Offset: 0x0430 |            |             | Register Name: HCPORT2SC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 8:5            | R/W        | 0x5         | <p>from the port).</p> <p>PLS<br/>Port Link State<br/>Default = RxDetect ('5'). This field is used to power manage the port and reflects its current link state. When the port is in the Enabled state, system software may set the link U state by writing this field. System software may also write this field to force a Disabled to Disconnected state transition of the port.</p> <p>Write value and Description:</p> <p>0: The link shall transition to a U0 state from any of the U states.</p> <p>2: USB2 protocol ports only. The link should transition to the U2 State.</p> <p>3: The link shall transition to a U3 state from any of the U states. This action selectively suspends the device connected to this port. While the Port Link State = U3, the hub does not propagate downstream-directed traffic to this port, but the hub shall respond to resume signaling from the port.</p> <p>5: USB3 protocol ports only. If the port is in the Disabled state (PLS = Disabled, PP = 1), then the link shall transition to a RxDetect state and the port shall transition to the Disconnected state, else ignored.</p> <p>10: USB3 protocol ports only. Shall enable a link transition to the Compliance state, i.e. <math>CTE = '1'</math>.</p> <p>1, 4, 6-9, 11-14: Ignored.</p> <p>15: USB2 protocol ports only. If the port is in the U3 state (PLS = U3), then the link shall remain in the U3 state and the port shall transition to the U3Exit sub-state, else ignored.</p> <p><b>Note:</b> The Port Link State Write Strobe (LWS) shall also be set to '1' to write this field.</p> <p><b>For USB2 protocol ports:</b> Writing a value of '2' to this field shall request LPM, asserting L1 signaling on the USB2 bus. Software may read this field to determine</p> |

| Offset: 0x0430 |            |             | Register Name: HCPORT2SC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                |            |             | <p>if the transition to the U2 state was successful. Writing a value of '0' shall de-assert L1 signaling on the USB. Writing a value of '1' shall have no effect. The U1 state shall never be reported by a USB2 protocol port.</p> <p>Read value and Meaning:</p> <ul style="list-style-type: none"> <li>0: Link is in the U0 State</li> <li>1: Link is in the U1 State</li> <li>2: Link is in the U2 State</li> <li>3: Link is in the U3 State (Device Suspended)</li> <li>4: Link is in the Disabled State</li> <li>5: Link is in the RxDetect State</li> <li>6: Link is in the Inactive State</li> <li>7: Link is in the Polling State</li> <li>8: Link is in the Recovery State</li> <li>9: Link is in the Hot Reset State</li> <li>10: Link is in the Compliance Mode State</li> <li>11: Link is in the Test Mode State</li> <li>12-14: Reserved</li> <li>15: Link is in the Resume State</li> </ul> <p>This field is undefined if PP = '0'. <b>Note: Transitions between different states are not reflected until the transition is complete.</b></p> |
| 4              | R/W        | 0x0         | <p>PR<br/>Port Reset</p> <p>1' = Port Reset signaling is asserted. '0' = Port is not in Reset. When software writes a '1' to this bit (from a '0') the bus reset sequence is initiated; USB2 protocol ports shall execute the bus reset sequence as defined in the USB2 Spec. USB3 protocol ports shall execute the Hot Reset sequence as defined in the USB3 Spec. PR remains set until reset signaling is completed by the root hub.</p> <p>Note that software shall write a '1' to this flag to transition a USB2 port from the Polling state to the Enabled state.</p> <p>This flag is '0' if PP is '0'.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 3              | R          | 0x0         | OCA<br>Over-Current Active                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

| Offset: 0x0430 |            |             | Register Name: HCPORT2SC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                |            |             | '1' = This port currently has an over-current condition. '0' = This port does not have an over-current condition. This bit shall automatically transition from a '1' to a '0' when the over-current condition is removed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 2              | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 1              | R/W        | 0x0         | <p>PED<br/>Port Enabled/Disabled<br/>'1' = Enabled. '0' = Disabled.<br/>Ports may only be enabled by the xHC. Software cannot enable a port by writing a '1' to this flag. A port may be disabled by software writing a '1' to this flag.</p> <p>This flag shall automatically be cleared to '0' by a disconnect event or other fault condition.</p> <p>Note that the bit status does not change until the port state actually changes. There may be a delay in disabling or enabling a port due to other host controller or bus events.</p> <p>When the port is disabled (PED = '0') downstream propagation of data is blocked on this port, except for reset.</p> <p>For USB2 protocol ports:<br/>When the port is in the Disabled state, software shall reset the port (PR = '1') to transition PED to '1' and the port to the Enabled state.</p> <p>For USB3 protocol ports:<br/>When the port is in the Polling state (after detecting an attach), the port shall automatically transition to the Enabled state and set PED to '1' upon the completion of successful link training.</p> <p>When the port is in the Disabled state, software shall write a '5' (RxDetect) to the PLS field to transition the port to the Disconnected state.</p> <p>PED shall automatically be cleared to '0' when PR is set to '1', and set to '1' when PR transitions from '1' to '0' after a successful reset. Refer to Port Reset (PR) bit for more information on how the PED bit is managed.</p> <p>Note that when software writes this bit to a '1', it shall also write a '0' to the PR bit.</p> |

| Offset: 0x0430 |            |             | Register Name: HCPORT2SC                                                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                       |
|                |            |             | This flag is '0' if PP is '0'.                                                                                                                                                                                                                                                                                                    |
| 0              | R          | 0x0         | <p>CCS<br/>Current Connect Status<br/>'1' = A device is connected to the port. '0' = A device is not connected</p> <p>This value reflects the current state of the port, and may not correspond directly to the event that caused the Connect Status Change (CSC) bit to be set to '1'.</p> <p>This flag is '0' if PP is '0'.</p> |

#### 8.11.5.22 0x0434 xHC Port2 PM Status and Control Register (USB3 Protocol) (Default Value:0x0000\_0000)

| Offset: 0x0434 |            |             | Register Name: HCPORT2PMSC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 31:17          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 16             | R/W        | 0x0         | <p>FLA<br/>Force Link PM Accept<br/>When this bit is set to '1', the port shall generate a Set Link Function LMP with the Force_LinkPM_Accept bit asserted. When this bit is cleared to '0', the port shall generate a <i>Set Link Function</i> LMP with the Force_LinkPM_Accept bit de-asserted</p> <p>This flag shall be set to '0' by the assertion of PR to '1' or when CCS = transitions from '0' to '1'. Writes to this flag have no effect if PP = '0'.</p> <p>The Set Link Function LMP is sent by the xHC to the device connected on this port when this bit transitions from '0' to '1'. Refer to Sections 8.4.1, 10.4.2.2 and 10.4.2.9 of the USB3 specification for more details.</p> <p>Improper use of the SS Force_LinkPM_Accept functionality can impact the performance of the link significantly. This bit shall only be used for compliance and testing purposes. Software shall ensure that there are no pending packets at the link level before setting this bit.</p> <p>This flag is '0' if PP is '0'.</p> |
| 15:8           | R/W        | 0x00        | U2TO<br>U2 Timeout                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

| Offset: 0x0434 |            |             | Register Name: HCPORT2PMSC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                |            |             | <p>Timeout value for U2 inactivity timer. If equal to 0xFF, the port is disabled from initiating U2 entry. This field shall be set to '0' by the assertion of PR to '1'.</p> <p>The following are permissible values:</p> <ul style="list-style-type: none"> <li>0x00: Zero</li> <li>0x01: 256 us</li> <li>0x02: 512 us</li> <li>...</li> <li>0xFE: 65.024 ms</li> <li>0xFF: Infinite</li> </ul> <p>A U2 Inactivity Timeout LMP shall be sent by the xHC to the device connected on this port when this field is written.</p> <p>Refer to Sections 8.4.3 and 10.4.2.10 of the USB3 specification for more details.</p> |
| 7:0            | R/W        | 0x00        | <p>U1TO<br/>U1 Timeout</p> <p>Timeout value for U1 inactivity timer. If equal to 0xFF, the port is disabled from initiating U1 entry, this field shall be set to '0' by the assertion of PR to '1'.</p> <p>The following are permissible values:</p> <ul style="list-style-type: none"> <li>0x00: Zero</li> <li>0x01: 1 us</li> <li>0x02: 1 us</li> <li>...</li> <li>0x7F: 127us</li> <li>0x80-0xFE: Reserved</li> <li>0xFF: Infinite</li> </ul>                                                                                                                                                                       |

#### 8.11.5.23 0x0438 xHC Port2 Link Info Register (USB3 Protocol) (Default Value:0x0000\_0000)

| Offset: 0x0438 |            |             | Register Name: HCPORT2LI                                                                                                                                                                      |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                   |
| 31:24          | /          | /           | /                                                                                                                                                                                             |
| 23:20          | R          | 0x0         | <p>RLC<br/>Rx Lane Count</p> <p>This field that identifies the number of Receive Lanes negotiated by the port. This is a "zero-based" value, where 0 to 15 represents Lane Counts of 1 to</p> |

| Offset: 0x0438 |            |             | Register Name: HCPORT2LI                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                       |
|                |            |             | 16, respectively. This value is valid only when <i>CCS</i> = '1'. <i>RLC</i> shall equal '0' for a simplex Sublink.                                                                                                                                                                               |
| 19:16          | R          | 0x0         | TLC<br>Tx Lane Count<br>This field identifies the number of Transmit Lanes negotiated by the port. This is a "zero-based" value, where 0 to 15 represents Lane Counts of 1 to 16, respectively. This value is valid only when <i>CCS</i> = '1'. <i>TLC</i> shall equal '0' for a simplex Sublink. |
| 15:0           | R          | 0x0000      | LEC<br>Link Error Count<br>This field returns the number of link errors detected by the port. This value shall be reset to '0' by the assertion of a Chip Hardware Reset, HCRST, when PR transitions from '1' to '0', or when CCS = transitions from '0' to '1'.                                  |

#### 8.11.5.24 0x1000 xHC Microframe Index Register (Default Value:0x0000\_0000)

| Offset: 0x1000 |            |             | Register Name: HCMFINDEX                                                                                                                                                          |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                       |
| 31:14          | /          | /           | /                                                                                                                                                                                 |
| 13:0           | R          | 0x0000      | MFI<br>Micro-Frame Index<br>The value in this register increments at the end of each micro-frame (e.g. 125us). Bits [13:3] may be used to determine the current 1ms. Frame index. |

#### 8.11.5.25 0x1020 xHC Interrupt 0 Management Register (Default Value:0x0000\_0000)

| Offset: 0x1020 |            |             | Register Name: HCIMAN0                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                     |
| 31:2           | /          | /           | /                                                                                                                                                                                                                                                                                               |
| 1              | R/W        | 0x0         | IE<br>Interrupt Enable<br>This flag specifies whether the interrupter is capable of generating an interrupt. When this bit and the IP bit are set, the interrupter shall generate an interrupt when the interrupter Moderation Counter reaches '0'. If this bit is '0', then the interrupter is |

| Offset: 0x1020 |            |             | Register Name: HCIMAN0                                                                                                                                                                                                                                                                |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                           |
|                |            |             | prohibited from generation interrupts.                                                                                                                                                                                                                                                |
| 0              | R/W1C      | 0x0         | <p>IP<br/>Interrupt Pending<br/>This flag represents the current state of the interrupter. If IP = '1', an interrupt is pending for this interrupter. A '0' value indicates that no interrupt is pending for interrupter.</p> <p>This bit can be cleared by software writing '1'.</p> |

#### 8.11.5.26 0x1024 xHC Interrupt 0 Moderation Register (Default Value:0x0000\_0FA0)

| Offset: 0x1024 |            |             | Register Name: HCIMOD0                                                                                                                                                                                                                                                                                                                                                                        |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                   |
|                |            |             | IMODC<br>Interrupt Moderation Counter<br>Down counter. Loaded with the IMODI value whenever IP is cleared to '0', counts down to '0', and stops. The associated interrupt shall be signaled whenever this counter is '0', the Event Ring is not empty, the IE and IP flags = '1', and EHB = '0'.<br>This counter may be directly written by software at any time to alter the interrupt rate. |
| 31:16          | R/W        | 0x0000      |                                                                                                                                                                                                                                                                                                                                                                                               |
|                |            |             | IMODI<br>Interrupt Moderation Interval<br>Minimum inter-interrupt interval. The interval is specified in 250ns increments. A value of '0' disables interrupt throttling logic and interrupts shall be generated immediately if IP = '0', EHB = '0', and the Event Ring is not empty.<br>The default value is 4000 (1ms).                                                                      |
| 15:0           | R/W        | 0x0FA0      |                                                                                                                                                                                                                                                                                                                                                                                               |

#### 8.11.5.27 0x1028 xHC Interrupt 0 Event Ring Segment Table Size Register (Default Value:0x0000\_0000)

| Offset: 0x1028 |            |             | Register Name: HCERSTSZ0                                                                                                                        |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                     |
|                |            |             | /                                                                                                                                               |
| 31:16          | /          | /           | /                                                                                                                                               |
|                |            |             | ERSTSZ<br>Event Ring Segment Table Size<br>This field identifies the number of valid Event Ring Segment Table entries in the Event Ring Segment |
| 15:0           | R/W        | 0x0         |                                                                                                                                                 |

| Offset: 0x1028 |            |             | Register Name: HCERSTSZ0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                |            |             | <p>Table pointed to by the Event Ring Segment Table Base Address register. The maximum value supported by an xHC implementation for this register is defined by the ERST Max field in the HCSPARAMS2 register.</p> <p>For Secondary Interrupters: Writing a value of '0' to this field disables the Event Ring. Any events targeted at this Event Ring when it is disabled shall result in undefined behavior of the Event Ring.</p> <p>For the Primary Interrupter: Writing a value of '0' to this field shall result in undefined behavior of the Event Ring. The Primary Event Ring cannot be disabled.</p> |

#### 8.11.5.28 0x1030 xHC Interrupt 0 Event Ring Segment Table Base Address Low Register (Default 0x1030 Value:0x0000\_0000)

| Offset: 0x1030 |            |             | Register Name: HCERSTBAL0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 31:6           | R/W        | 0x0000      | <p>ERSTBAL</p> <p>Event Ring Segment Table Base Address Low</p> <p>This field defines the low order bits [31:6] of the start address of the Event Ring Segment Table.</p> <p>Writing this register sets the Event Ring State Machine: EREP Advancement to the Start state.</p> <p>For Secondary Interrupters: This field may be modified at any time.</p> <p>For the Primary Interrupter: This field shall not be modified if <i>HCHalted</i>(HCH) = '0'.</p> <p><b>Note:</b> If a system is incapable of issuing Qword accesses, then writes to the 64-bit address fields shall be performed using 2 Dword accesses; low Dword-first, high-Dword second.</p> |
| 5:0            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

#### 8.11.5.29 0x1034 xHC Interrupt 0 Event Ring Segment Table Base Address High Register (Default 0x1034 Value:0x0000\_0000)

| Offset: 0x1034 |            |             | Register Name: HCERSTBAH0 |
|----------------|------------|-------------|---------------------------|
| Bit            | Read/Write | Default/Hex | Description               |

| Offset: 0x1034 |            |             | Register Name: HCERSTBAH0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 31:0           | R/W        | 0x0000      | <p>ERSTBAH<br/>                     Event Ring Segment Table Base Address High<br/>                     This field defines the high order bits [63:32] of the start address of the Event Ring Segment Table.<br/>                     Writing this register sets the Event Ring State Machine: EREP Advancement to the Start State.<br/>                     For Secondary Interrupters: This field may be modified at any time.<br/>                     For the Primary Interrupter: This field shall not be modified if <i>HCHalted</i>(HCH) = '0'.<br/>                     This field shall not be modified if <i>HCHalted</i>(HCH) = '0'.</p> |

#### 8.11.5.30 0x1038 xHC Interrupt 0 Event Ring Dequeue Poiter Low Register (Default Value:0x0000\_0000)

| Offset: 0x1038 |            |             | Register Name: HCERDPL0                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                              |
| 31:4           | R/W        | 0x0000      | <p>ERDPL<br/>                     Event Ring Dequeue Pointer Low<br/>                     This field defines the low order bits [31:4] of the start address of the current Event Ring Dequeue Pointer.<br/> <b>Note:</b> If a system is incapable of issuing Qword accesses, then writes to the 64-bit address fields shall be performed using 2 Dword accesses; low Dword-first, high-Dword second.</p> |
| 3              | R/W1C      | 0x0         | <p>EHB<br/>                     Event Handler Busy<br/>                     This flag shall be set to '1' when the IP bit is set to '1' and cleared to '0' by software when the Dequeue Pointer register is written.</p>                                                                                                                                                                                 |
| 2:0            | R/W        | 0x0         | <p>DESI<br/>                     Dequeue ERST Segment Index<br/>                     This field may be used by the xHC to accelerate checking the Event Ring full condition. This field is written with the low order 3 bits of the offset of the ERST entry which defines the Event Ring segment that the Event Ring Dequeue Pointer resides in.</p>                                                    |

### 8.11.5.31 0x103C xHC Interrupt 0 Event Ring Dequeue Pointer High Register (Default Value:0x0000\_0000)

| Offset: 0x103C |            |             | Register Name: HCERDPH0                                                                                                                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                         |
| 31:0           | R/W        | 0x0000      | <p>ERDPH<br/>Event Ring Dequeue Pointer High<br/>This field defines the high order bits [63:32] of the start address of the current Event Ring Dequeue Pointer.</p> |

### 8.11.5.32 0x2000 + 4\*n (N = 0-64) xHC Doorbell Register N (n=0, 1, ……, 64) (Default Value:0x0000\_0000)

| Offset: 0x2000 + 4*n (N = 0-64) |            |             | Register Name: HCDBRn (N = 0-64)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------------------------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                             | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 31:16                           | R/W        | 0x0000      | <p>DBSID<br/>Doorbell Stream ID<br/>If the endpoint of a Device Context Doorbell defines Streams, then this field shall be used to identify which Stream of the endpoint the doorbell reference is targeting. System software is responsible for ensuring that the value written to this field is valid. If the endpoint defines Streams (MaxPStreams &gt; 0), then 0, 65535 (No Stream) and 65534 (Prime) are reserved Stream ID values and shall not be written to this field.<br/>If the endpoint does not define Streams (MaxPStreams = 0) and a non-'0' value is written to this field, the doorbell reference shall be ignored. This field only applies to Device Context Doorbells and shall be cleared to '0' for Host Controller Command Doorbells.<br/>This field returns '0' when read.</p> |
| 15:8                            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 7:0                             | R/W        | 0x00        | <p>DBT<br/>Doorbell Target<br/>This field defines the target of the doorbell reference. The table below defines the xHC notification that is generated by ringing the doorbell. Note that Doorbell Register 0 is dedicated to Command Ring and decodes this field differently than the other Doorbell Registers.<br/><br/>Device Context Doorbells (n = 1-64)</p>                                                                                                                                                                                                                                                                                                                                                                                                                                      |

| Offset: 0x2000 + 4*n (N = 0-64) |            |             | Register Name: HCDBRn (N = 0-64)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------------------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                             | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                                 |            |             | <p>0: Reserved<br/> 1: Control EP0 Enqueue Pointer Update<br/> 2: EP 1 OUT Enqueue Pointer Update<br/> 3: EP 1 IN Enqueue Pointer Update<br/> 4: EP 2 OUT Enqueue Pointer Update<br/> 5: EP 2 IN Enqueue Pointer Update<br/> ...<br/> 30: EP 15 OUT Enqueue Pointer Update<br/> 31: EP 15 IN Enqueue Pointer Update<br/> 32-247: Reserved<br/> 248-255: Vendor Defined</p> <p>Host Controller Doorbell (n = 0)<br/> 0: Command Doorbell<br/> 1-247: Reserved<br/> 248-255: Vendor Defined</p> <p>This field returns '0' when read and should be treated as "undefined" by software.<br/> When the Command Doorbell is written, the DB Stream ID field shall be cleared to '0'.</p> |

#### 8.11.5.33 0x0440 xHC USB Legacy Support Capability Register (Default Value:0x0000\_0401)

| Offset: 0x0440 |            |             | Register Name: HCUSBLEGSUP                                                                                                                                                                               |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                              |
| 31:25          | /          | /           | /                                                                                                                                                                                                        |
| 24             | R/W        | 0x0         | OOS<br>HC OS Owned Semaphore<br>System software sets this bit to request ownership of the xHC. Ownership is obtained when this bit reads as '1' and the HC BIOS Owned Semaphore bit reads as '0'.        |
| 23:17          | /          | /           | /                                                                                                                                                                                                        |
| 16             | R/W        | 0x0         | BOS<br>HC BIOS Owned Semaphore<br>The BIOS sets this bit to establish ownership of the xHC. System BIOS will set this bit to a '0' in response to a request for ownership of the xHC by system software. |
| 15:8           | R          | 0x04        | NCP                                                                                                                                                                                                      |

| Offset: 0x0440 |            |             | Register Name: HCUSBLEGSUP                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                |
|                |            |             | <p>Next Capability Pointer<br/>This field indicates the location of the next capability with respect to the effective address of this capability..</p>                                                                                                                                                                                     |
| 7:0            | R          | 0x01        | <p>CID<br/>Capability ID<br/>This field identifies the xHCI Extended capability.<br/>Refer to xHCI Spec for a list of the valid xHCI extended capabilities.</p> <p>This extended capability requires one additional 32-bit register for control/status information (HCUSBLEGCTLSTS), and this register is located at offset xECP+0x04.</p> |

#### 8.11.5.34 0x0444 xHC USB Legacy Support Control/Status Register (Default Value:0x0000\_0000)

| Offset: 0x0444 |            |             | Register Name: HCUSBLEGCTRLSTS                                                                                                                                                                                                       |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                          |
| 31             | R/W1C      | 0x0         | <p>SBAR<br/>SMI on BAR<br/>This bit is set to '1' whenever the Base Address Register (BAR) is written.<br/>This bit can be cleared by software writing '1'.</p>                                                                      |
| 30             | R/W1C      | 0x0         | <p>SPC<br/>SMI on PCI Command<br/>This bit is set to '1' whenever the PCI Command Register is written.<br/>This bit can be cleared by software writing '1'.</p>                                                                      |
| 29             | R/W1C      | 0x0         | <p>SOOC<br/>SMI on OS Ownership Change<br/>This bit is set to '1' whenever the HC OS Owned Semaphore bit in HCUSBLEGSUP register transitions from '1' to '0' or '0' to '1'.<br/>This bit can be cleared by software writing '1'.</p> |
| 28:21          | /          | /           | /                                                                                                                                                                                                                                    |
| 20             | R          | 0x0         | <p>SHSE<br/>SMI on Host System Error<br/>Shadow bit of Host System Error (HSE) bit in the HCUSBSTS register.<br/>To clear this bit to a '0', system software shall write a '1' to the Host System Error (HSE) bit in the</p>         |

| Offset: 0x0444 |            |             | Register Name: HCUSBLEGCTRLSTS                                                                                                                                                                                                                                    |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                       |
|                |            |             | HCUSBSTS register.                                                                                                                                                                                                                                                |
| 19:17          | /          | /           | /                                                                                                                                                                                                                                                                 |
|                |            |             | SEI<br>SMI on Event Interrupt<br>Shadow bit of Event Interrupt (EINT) bit in the HCUSBSTS register.<br>This bit follows the state the Event Interrupt (EINT) bit in the HCUSBSTS register, e.g. it automatically clears when EINT clears or set when EINT is set. |
| 16             | R          | 0x0         |                                                                                                                                                                                                                                                                   |
| 15             | R/W        | 0x0         | SBE<br>SMI on BAR Enable<br>When this bit is a '1' AND SMI on BAR is '1', then the host controller will issue an SMI.                                                                                                                                             |
| 14             | R/W        | 0x0         | SPCE<br>SMI on PCI Command Enable<br>When this bit is a '1' AND SMI on PCI Command is '1', then the host controller will issue an SMI.                                                                                                                            |
| 13             | R/W        | 0x0         | SOOE<br>SMI on OS Ownership Enable<br>When this bit is a '1' AND the OS Ownership Change bit is '1', the host controller will issue an SMI.                                                                                                                       |
| 12:5           | /          | /           | /                                                                                                                                                                                                                                                                 |
| 4              | R/W        | 0x0         | SHSEE<br>SMI on Host System Error Enable<br>When this bit is a '1', and the SMI on Host System Error bit in this register is a '1', the host controller will issue an SMI immediately.                                                                            |
| 3:1            | /          | /           | /                                                                                                                                                                                                                                                                 |
| 0              | R/W        | 0x0         | USE<br>USB SMI Enable<br>When this bit is a '1', and the SMI on Event Interrupt bit in this register is a '1', the host controller will issue an SMI immediately.                                                                                                 |

#### 8.11.5.35 0x0490 xHC Support Protocol Capability 1 Revision Register (Default Value:0x0200\_0402)

| Offset: 0x0490 |            |             | Register Name: HCSPC1REV                                            |
|----------------|------------|-------------|---------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                         |
|                |            |             | MajorRev<br>Minor Revision<br>Minor Specification Release Number in |
| 31:24          | R          | 0x02        |                                                                     |

| Offset: 0x0490 |            |             | Register Name: HCSPC1REV                                                                                                                                                                                 |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                              |
|                |            |             | Binary-Coded Decimal. This field identifies the major release number component of the specification with which the xHC is compliant.                                                                     |
| 23:16          | R          | 0x00        | MinorRev<br>Minor Revision<br>Minor Specification Release Number in Binary-Coded Decimal. This field identifies the minor release number component of the specification with which the xHC is compliant. |
| 15:8           | R          | 0x04        | NCP<br>Next Capability Pointer<br>This field indicates the location of the next capability with respect to the effective address of this capability..                                                    |
| 7:0            | R          | 0x02        | CID<br>Capability ID<br>This field identifies the xHCI Extended capability. Refer to xHCI Spec for a list of the valid xHCI extended capabilities.                                                       |

#### 8.11.5.36 0x0494 xHC Support Protocol Capability 1 String Register (Default Value:0x2042\_5355)

| Offset: 0x0494 |            |             | Register Name: HCSPC1STR                                                                                                                                             |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                          |
| 31:0           | R          | 0x20425355  | NAME<br>Name String<br>This field is a mnemonic name string that references the specification with which the xHC is compliant. Four ASCII characters may be defined. |

#### 8.11.5.37 0x0498 xHC Support Protocol Capability 1 Port Register (Default Value:0x0001\_0101)

| Offset: 0x0498 |            |             | Register Name: HCSPC1PRT                                                                                                                                                  |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                               |
| 31:28          | R          | 0x0         | PSIC<br>Protocol Speed ID Count<br>This field indicates the number of Protocol Speed ID (PSI) Dwords that the xHCI Supported Protocol Capability data structure contains. |
| 27:16          | R          | 0x001       | PD                                                                                                                                                                        |

| Offset: 0x0498 |            |             | Register Name: HCSPC1PRT                                                                                                                                                                                |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                             |
|                |            |             | Protocol Defined<br>This field is reserved for protocol specific definitions.                                                                                                                           |
| 15:8           | R          | 0x01        | CPCNT<br>Compatible Port Count<br>This field identifies the number of consecutive Root Hub Ports (starting at the Compatible Port Offset) that support this protocol. Valid values are '1' to MaxPorts. |
| 7:0            | R          | 0x01        | CPOFF<br>Compatible Port Offset<br>This field specifies the starting Port Number of Root Hub Ports that support this protocol. Valid values are '1' to MaxPorts.                                        |

#### 8.11.5.38 0x04A0 xHC Support Protocol Capability 2 Revision Register (Default Value:0x0300\_0002)

| Offset: 0x04A0 |            |             | Register Name: HCSPC2REV                                                                                                                                                                                 |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                              |
| 31:24          | R          | 0x03        | MajorRev<br>Minor Revision<br>Minor Specification Release Number in Binary-Coded Decimal. This field identifies the major release number component of the specification with which the xHC is compliant. |
| 23:16          | R          | 0x00        | MinorRev<br>Minor Revision<br>Minor Specification Release Number in Binary-Coded Decimal. This field identifies the minor release number component of the specification with which the xHC is compliant. |
| 15:8           | R          | 0x00        | NCP<br>Next Capability Pointer<br>This field indicates the location of the next capability with respect to the effective address of this capability..                                                    |
| 7:0            | R          | 0x02        | CID<br>Capability ID<br>This field identifies the xHCI Extended capability. Refer to xHCI Spec for a list of the valid xHCI extended capabilities.                                                       |

#### 8.11.5.39 0x04A4 xHC Support Protocol Capability 2 String Register (Default Value:0x2042\_5355)

| Offset: 0x04A4 |            |             | Register Name: HCSPC2STR                                                                                                                                             |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                          |
| 31:0           | R          | 0x20425355  | NAME<br>Name String<br>This field is a mnemonic name string that references the specification with which the xHC is compliant. Four ASCII characters may be defined. |

#### 8.11.5.40 0x04A8 xHC Support Protocol Capability 2 Port Register (Default Value:0x0000\_0102)

| Offset: 0x04A8 |            |             | Register Name: HCSPC2PRT                                                                                                                                                                                |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                             |
| 31:28          | R          | 0x0         | PSIC<br>Protocol Speed ID Count<br>This field indicates the number of Protocol Speed ID (PSI) Dwords that the xHCI Supported Protocol Capability data structure contains.                               |
| 27:16          | R          | 0x000       | PD<br>Protocol Defined<br>This field is reserved for protocol specific definitions.                                                                                                                     |
| 15:8           | R          | 0x01        | CPCNT<br>Compatible Port Count<br>This field identifies the number of consecutive Root Hub Ports (starting at the Compatible Port Offset) that support this protocol. Valid values are '1' to MaxPorts. |
| 7:0            | R          | 0x02        | CPOFF<br>Compatible Port Offset<br>This field specifies the starting Port Number of Root Hub Ports that support this protocol. Valid values are '1' to MaxPorts.                                        |

#### 8.11.6 Global Register Description

##### 8.11.6.1 0xC100 Global Soc Bus Configuration Register 0 (Default Value:0x0000\_0001)

| Offset: 0xC100 |            |             | Register Name: GSBUSCFG0                                      |
|----------------|------------|-------------|---------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                   |
| 31:28          | R/W        | 0           | DatRdReqInfo<br>AHB-prot/AXI-cache/OCP-ReqInfo for Data Read. |

| Offset: 0xC100 |            |             | Register Name: GSBUSCFG0                                                                                                                                                                    |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                 |
|                |            |             | Input to BUS-GM.                                                                                                                                                                            |
| 27:24          | R/W        | 0           | DesRdReqInfo<br>AHB-prot/AXI-cache/OCP-ReqInfo for Descriptor Read.<br>Input to BUS-GM.                                                                                                     |
| 23:20          | R/W        | 0           | DatWrReqInfo<br>AHB-prot/AXI-cache/OCP-ReqInfo for Data Write.<br>Input to BUS-GM.                                                                                                          |
| 19:16          | R/W        | 0           | DesWrReqInfo<br>AHB-prot/AXI-cache/OCP-ReqInfo for Descriptor Write.<br>Input to BUS-GM.                                                                                                    |
| 15:12          | /          | /           | /                                                                                                                                                                                           |
| 11             | R/W        | 0           | DatBigEnd<br>Data Access is Big Endian<br>This bit controls the endian mode for data accesses.<br>0: Little-endian (default)<br>1: Big-endian<br>this bit must be set to zero.              |
| 10             | R/W        | 0           | DescBigend<br>Descriptor Access is Big-Endian<br>This bit controls the endian mode for descriptor accesses.<br>0: Little-endian (default)<br>1: Big-endian<br>this bit must be set to zero. |
| 9:8            | /          | /           | /                                                                                                                                                                                           |
| 7              | R/W        | 0           | INCR256BrstEna<br>INCR256 Burst Type Enable<br>For the AHB/AXI configuration, if software set this bit to "1", the AHB/AXI master uses INCR to do the 256-beat burst. Input to BUS-GM.      |
| 6              | R/W        | 0           | INCR128BrstEna<br>INCR128 Burst Type Enable<br>For the AHB/AXI configuration, if software set this bit to "1", the AHB/AXI master uses INCR to do the 128-beat burst. Input to BUS-GM.      |
| 5              | R/W        | 0           | INCR64BrstEna<br>INCR64 Burst Type Enable<br>For the AHB/AXI configuration, if software set this bit to "1", the AHB/AXI master uses INCR to do the                                         |

| Offset: 0xC100 |            |             | Register Name: GSBUSCFG0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                |            |             | 64-beat burst.Input to BUS-GM.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 4              | R/W        | 0           | INCR32BrstEna<br>INCR32 Burst Type Enable<br>For the AHB/AXI configuration, if software set this bit to "1", the AHB/AXI master uses INCR to do the 32-beat burst.Input to BUS-GM.                                                                                                                                                                                                                                                                                                                                                                          |
| 3              | R/W        | 0           | INCR16BrstEna<br>INCR16 Burst Type Enable<br>For the AHB/AXI configuration, if software set this bit to "1", the AHB/AXI master uses INCR to do the 16-beat burst.Input to BUS-GM.                                                                                                                                                                                                                                                                                                                                                                          |
| 2              | R/W        | 0           | INCR8BrstEna<br>INCR8 Burst Type Enable<br>For the AHB/AXI configuration, if software set this bit to "1", the AHB/AXI master uses INCR to do the 8-beat burst.Input to BUS-GM.                                                                                                                                                                                                                                                                                                                                                                             |
| 1              | R/W        | 0           | INCR4BrstEna<br>INCR4 Burst Type Enable<br>For the AXI configuration, when this bit is enabled the controller is allowed to do bursts of beat length 1, 2, 3, and 4. It is highly recommended that this bit is enabled to prevent descriptor reads and writes from being broken up into separate transfers. Input to BUS-GM.                                                                                                                                                                                                                                |
| 0              | R/W        | 1           | INCRBrstEna<br>Undefined Length INCR Burst Type Enable<br>When enabled, this has higher priority than other burst types.<br><br>For the AHB/AXI configuration. if this bit is set to "1", AHB/AXI master tries to do only one INCR burst for each transfer unless it has to break it at a page boundary.<br><br>If this bit is set to "0", the AHB/AXI master may still use INCR burst type at the beginning and end bursts of transfers to align the address. The middle bursts are INCR4/8/16, depending when the type is enabled.<br><br>Input to BUS-GM |

### 8.11.6.2 0xC104 Global Soc Bus Configuration Register 1 (Default Value:0x0000\_6F00)

| Offset: 0xC104 |            |             | Register Name: GSBUSCFG1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 31:17          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 16:13          | R/W        | 0x3         | <p>ExtdPipeTransLimit<br/>AXI Pipelined Transfers Extended Burst Request Limit<br/>The {ExtdPipeTransLimit, PipeTransLimit} fields controls the number of outstanding extended pipelined transfer requests the AXI master pushes to the AXI slave.<br/>When the AXI master reaches this limit, it does not make any more requests on the AXI ARADDR and AWADDR buses until the associated data phases complete.</p> <p>This field is encoded as follows:<br/>'h0: 1 request<br/>'h1: 2 requests<br/>'h2: 3 requests<br/>'h3: 4 requests<br/>and, so on</p> |
| 12             | R/W        | 0           | <p>EN1KPAGE<br/>1k Page Boundary Enable<br/>By default (this bit is disabled) the AXI breaks transfers at the 4k page boundary.<br/>When this bit is enabled, the AXI master (DMA data) breaks transfers at the 1k page boundary.</p>                                                                                                                                                                                                                                                                                                                      |
| 11:8           | R/W        | 0xf         | <p>PipeTransLimit<br/>AXI Burst Request Limit<br/>The {ExtdPipeTransLimit, PipeTransLimit} fields controls the number of outstanding extended pipelined transfer requests the AXI master pushes to the AXI slave.<br/>When the AXI master reaches this limit, it does not make any more requests on the AXI ARADDR and AWADDR buses until the associated data phases complete.</p> <p>This field is encoded as follows:<br/>'h0: 1 request<br/>'h1: 2 requests<br/>'h2: 3 requests<br/>'h3: 4 requests</p>                                                 |

| Offset: 0xC104 |            |             | Register Name: GSBUSCFG1 |
|----------------|------------|-------------|--------------------------|
| Bit            | Read/Write | Default/Hex | Description              |
|                |            |             | and, so on               |
| 7:0            | /          | /           | /                        |

#### 8.11.6.3 0xC108 Global TX Threshold Control Register (Default Value:0x00F0\_0000)

| Offset: 0xC108 |            |             | Register Name: GTXTHRCFG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 31:27          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 26             | R/W        | 0x0         | <p>UsbTxPktCntSel<br/>USB Async ESS Transmit Packet Threshold Enable - Host/Device Modes<br/>This field enables/disables the USB transmission multi-packet thresholding for Async endpoints:<br/>0: USB transmission multi-packet thresholding is disabled; the controller starts transmission on the USB as soon as one packet has been fetched into the corresponding TXFIFO.<br/>1: USB transmission multi-packet thresholding is enabled. The controller can only start transmission on the USB after USB Transmit Packet Count amount of packets for the USB transaction (burst) are already in the corresponding TXFIFO. This mode is valid in both host and device mode. It is only used for Enhanced SuperSpeed.<br/>In device mode, the controller can send ERDY on the USB after USB Transmit Packet Count amount of packets for the USB transaction (burst) are already in the corresponding TXFIFO of a Bulk IN endpoint</p> |
| 25:21          | R/W        | 0x7         | <p>USBTxPktCnt<br/>USB Async ESS Transmit Packet Threshold Count - Host/Device Modes<br/>This field specifies the number of packets that must be in the TXFIFO before the controller can start transmission for the corresponding USB transaction (burst) for Async endpoints. This field is only valid when the USB Async ESS Transmit Packet Threshold Enable field is set to one.<br/>For device mode, this field specifies the number of packets that must be in the TXFIFO before the controller can start transmission of ERDY for the corresponding USB transaction (burst) of Bulk IN</p>                                                                                                                                                                                                                                                                                                                                        |

| Offset: 0xC108 |            |             | Register Name: GTXTHRCFG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                |            |             | <p>endpoint.</p> <p>Valid values for this field is 1 to 16.</p> <p>Note:</p> <p>In host mode, this field must be less than or equal to the USB Maximum TX Burst Size field.</p> <p>In device mode, this field must be less than or equal to the USB endpoint maximum Burst Size amongst all endpoints.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 20:16          | R/W        | 0x10        | <p>USBMaxTxBurstSize</p> <p>USB Async ESS Maximum TX Burst Size - Host Mode Only</p> <p>When USBTxPktCntSel is 1, this field specifies the Maximum ESS Bulk OUT burst that the controller can execute. When the system bus is slower than the USB, TXFIFO can underrun during a long burst.</p> <p>You can program a smaller value to this field to limit the TX burst size that the controller can execute.</p> <p>It only applies to ESS Bulk OUT endpoints in the host mode. Valid values are from 1 to 16.</p> <p>Note: This field can only be set to 2, 4, 8 or 16.</p>                                                                                                                                                                                                                                                                                         |
| 15             | R/W        | 0x0         | <p>UsbTxThrNumPktSel_HS_Prd</p> <p>USB HS High Bandwidth Periodic Transmit Packet Threshold Enable - Host Mode Only</p> <p>This field enables/disables the USB HS High Bandwidth Periodic transmission multi-packet thresholding&gt;</p> <p>0: USB HS High Bandwidth Periodic transmission multi-packet thresholding is disabled; the controller can start transmission on the USB as soon as one packet has been fetched into the corresponding TXFIFO.</p> <p>1: USB HS High Bandwidth Periodic transmission multi-packet thresholding is enabled. The controller can start transmission on the USB only after USB HS High Bandwidth Periodic Transmit Packet Threshold Count number of packets for the Periodic High Bandwidth USB transaction is already in the corresponding TXFIFO. This mode is valid in host mode for high speed high bandwidth periodic</p> |

| Offset: 0xC108 |            |             | Register Name: GTXTHRCFG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                |            |             | endpoints                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 14:13          | R/W        | 0x0         | <p>UsbTxThrNumPkt_HS_Prd<br/>USB HS High Bandwidth Periodic Transmit Packet Threshold Count - Host Mode Only<br/>This field specifies the number of packets that must be available in the TXFIFO before the controller can start transmission for the Periodic High Bandwidth USB transaction. This field is only valid when the USB HS High Bandwidth Periodic Transmit Packet Threshold Enable field is set to one. Valid values are from 1 to 3.</p>                                                                                                                                                                                                                               |
| 12:11          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 10             | R/W        | 0x0         | <p>UsbTxThrNumPktSel_Prd<br/>USB Periodic ESS Transmit Packet Threshold Enable - Host Mode Only<br/>This field enables/disables the USB Periodic transmission multi-packet thresholding:<br/>0: USB transmission multi-packet thresholding is disabled; the controller starts transmission on the USB as soon as one packet has been fetched into the corresponding TXFIFO.<br/>1: USB transmission multi-packet thresholding is enabled. The controller can start transmission on the USB only after USB Periodic ESS Transmit Packet Threshold Count amount of packets for the USB transaction (burst) has been fetched into the corresponding TXFIFO. It is used only for ESS.</p> |
| 9:5            | R/W        | 0x0         | <p>UsbTxThrNumPkt_Prd<br/>USB Periodic ESS Transmit Packet Threshold Count - Host Mode Only<br/>This field specifies the number of packets that must be in the TXFIFO before the controller can start transmission for the corresponding USB transaction (burst). This field is valid only when the USB Periodic ESS Transmit Packet Threshold Enable field (UsbTxThrNumPktSel_Prd) is set to one. Valid values are from 1 to 16.<br/>Note: This field must be less than or equal to the USB Maximum Periodic TX Burst Size field.</p>                                                                                                                                                |
| 4:0            | R/W        | 0x0         | UsbMaxTxBurstSize_Prd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

| Offset: 0xC108 |            |             | Register Name: GTXTHRCFG                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                         |
|                |            |             | <p>USB Maximum Periodic ESS TX Burst Size - Host Mode Only<br/> When UsbTxThrNumPktSel_Prd is 1, this field specifies the Maximum Periodic OUT burst the controller can execute. When the system bus is slower than the USB, TXFIFO can underrun during a long burst.</p> <p>Note: This field can only be set to 2, 4, 8 or 16.</p> |

#### 8.11.6.4 0xC10C Global RX Threshold Control Register (Default Value:0x00F0\_0000)

| Offset: 0xC10C |            |             | Register Name: GRXTHRCFG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 31:27          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 26             | R/W        | 0           | <p>USBRxPktCntSel<br/> USB Async ESS Receive Packet Threshold Enable - Host/Device Modes<br/> This field enables/disables the USB reception multi-packet thresholding:<br/> 0: The controller can only start reception on the USB when the RXFIFO has space for at least one packet.<br/> 1: The controller can only start reception on the USB when the RXFIFO has space for at least USBRxPktCnt amount of packets. This mode is valid in both host and device mode. It is only used for Enhanced SuperSpeed.<br/> In device mode,<br/> Setting this bit to 1 also enables the functionality of reporting NUMP in the ACK/ERDY TP based on the RXFIFO space instead of reporting a fixed NUMP derived from DCFG.NUMP for Bulk OUT endpoints.<br/> If you are using external buffer control (EBC) feature, disable this mode by setting USBRxPktCntSel to 0.</p> |
| 25:21          | R/W        | 0x7         | <p>UsbRxPktCnt<br/> USB Async ESS Receive Packet Threshold Count - Host/Device Modes<br/> In host mode, this field specifies the space (in terms of the number of packets) that must be available in the RXFIFO before the controller can start the corresponding USB RX transaction (burst).<br/> In device mode, this field specifies the space (in</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

| Offset: 0xC10C |            |             | Register Name: GRXTHRCFG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                |            |             | <p>terms of the number of packets) that must be available in the RXFIFO before the controller can send ERDY for a flow-controlled Bulk OUT endpoints.</p> <p>This field is valid only when the USB Async ESS Receive Packet Threshold Enable field is set to 1. The valid values for this field are from 1 to 16. Note: This field must be less than or equal to the USB Maximum Receive Burst Size field.</p>                                                                                                                                                                                                                                                                                                                         |
| 20:16          | R/W        | 0x10        | <p>UsbMaxRxBurstSize<br/>USB Async ESS Maximum Receive Burst Size - Host/Device Modes</p> <p>In host mode, this field specifies the Maximum Bulk IN burst the DWC_usb31 controller can perform. When the system bus is slower than the USB, RXFIFO can overrun during a long burst.</p> <p>You can program a smaller value to this field to limit the RX burst size that the controller can perform. It only applies to ESS Bulk endpoints in the host mode. In device mode, this field specifies the NUMP value that is sent in ERDY for a Bulk OUT endpoint. The programmed value should not exceed the RxFIFO size.</p> <p>This field is valid only when USBRxPktCntSel is 1. The valid values for this field are from 1 to 16.</p> |
| 15             | R/W        | 0           | <p>UsbRxThrNumPktSel_HS_Prd<br/>USB HS High Bandwidth Periodic Receive Packet Threshold Enable - Host Mode Only</p> <p>This field enables/disables the USB reception multi-packet thresholding:</p> <p>0: USB HS High Bandwidth Periodic Receive multi-packet thresholding is disabled; The controller can start reception on the USB as soon as the RXFIFO has space for one packet.</p> <p>1: USB HS High Bandwidth Periodic Receive multi-packet thresholding is enabled; the controller can only start reception on the USB when the RXFIFO has space for at least UsbRxThrNumPkt_HS_Prd amount of packets. This mode is valid in host mode for high speed high bandwidth periodic endpoints.</p>                                  |

| Offset: 0xC10C |            |             | Register Name: GRXTHRCFG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                |            |             | In device mode, this field specifies the NUMP value that will be sent in ERDY for an OUT endpoint. This field is valid only when USBRxPktCntSel is one. The valid values for this field are from 1 to 16.                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 14:13          | R/W        | 0x0         | UsbRxThrNumPkt_HS_Prd<br>USB HS High Bandwidth Periodic Receive Packet Threshold Count - Host Mode Only<br>This field specifies the maximum number of packet space needed in the RXFIFO before the controller can start a HS Periodic High Bandwidth USB transaction. This field is valid only when USBRxPktCntSel_HS_Prd is 1. The valid values for this field are from 1 to 3.                                                                                                                                                                                                                                                                                                        |
| 12:11          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 10             | R/W        | 0x0         | UsbRxThrNumPktSel_Prd<br>USB Periodic ESS Receive Packet Threshold Enable - Host Mode Only.<br>This field should be programmed to 0 in Device mode.<br>This field enables/disables the Periodic ESS USB reception multi-packet thresholding:<br>0: USB Periodic ESS Receive multi-packet thresholding is disabled; the controller can start reception on the USB as soon as the RXFIFO has space for one packet.<br>1: USB Periodic ESS Receive multi-packet thresholding is enabled; the controller can only start reception on the USB when the RXFIFO has space for at least UsbRxThrNumPkt_Prd amount of packets.<br>This mode is valid only in host mode. It is only used for ESS. |
| 9:5            | R/W        | 0x0         | UsbRxThrNumPkt_Prd<br>USB Periodic ESS Receive Packet Threshold Count - Host Mode Only.<br>This field should be programmed to 0 in Device mode.<br>This field specifies the minimum number of packet space needed in the RXFIFO before the controller can start a ESS periodic high-bandwidth USB transaction. This field is valid only when the USB Periodic ESS Receive Packet Threshold Enable field                                                                                                                                                                                                                                                                                 |

| Offset: 0xC10C |            |             | Register Name: GRXTHRCFG                                                                                                                                                                                                                                                                                                                                                |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                             |
|                |            |             | <p>is set to 1. Valid values are from 1 to 16.</p> <p>Note: This field must be less than or equal to the USB Maximum Periodic RX Burst Size field.</p>                                                                                                                                                                                                                  |
| 4:0            | R/W        | 0x0         | <p>UsbMaxRxBurstSize_Prd</p> <p>USB Maximum Periodic ESS RX Burst Size - Host Mode Only.</p> <p>This field should be programmed to 0 in Device mode.</p> <p>When UsbRxThrNumPktSel_Prd is 1, this field specifies the Maximum ESS Periodic IN burst the controller can execute. When the system bus is slower than the USB, RXFIFO can overrun during a long burst.</p> |

#### 8.11.6.5 0xC110 Global Core Control Register (Default Value:0x30C1\_2004)

| Offset: 0xC110 |            |             | Register Name: GCTL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 31:19          | R/W        | 0x618       | <p>PwrDnScale</p> <p>Power Down Scale</p> <p>The USB3 suspend_clk input replaces pipe3_rx_pclk as a clock source to a small part of the USB3 core that operates when the SS PHY is in its lowest power (P3) state, and therefore does not provide a clock.</p> <p>The Power Down Scale field specifies how many suspend_clk periods fit into a 16 kHz clock period.</p> <p>When performing the division, truncate the remainders instead of rounding up.</p> <p>For example, when using an 8-bit/16-bit/32-bit PHY and 25-MHz Suspend clock, Power Down Scale = <math>25000 \text{ kHz} / 16 \text{ kHz} = 13'd1562</math>.</p> <p>Note:</p> <p>Minimum Suspend clock frequency is 32 kHz</p> <p>Maximum Suspend clock frequency is 125 MHz</p> <p>The LTSSM uses Suspend clock for 12-ms and 100-ms timers during suspend mode.</p> <p>According to the USB 3.1 specification, the accuracy on these timers is 0% to +50%.</p> <p><math>12 \text{ ms} + 0\text{-}+50\% \text{ accuracy} = 18 \text{ ms}</math> (Range is 12 ms - 18 ms)</p> <p><math>100 \text{ ms} + 0\text{-}+50\% \text{ accuracy} = 150 \text{ ms}</math> (Range is 100 ms - 150 ms)</p> |

| Offset: 0xC110 |            |             | Register Name: GCTL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                |            |             | <p>- 150 ms).</p> <p>The suspend clock accuracy requirement is:<br/> <math>(12,000/62.5) * (GCTL[31:19]) * \text{actual suspend\_clk\_period}</math> should be between 12,000 and 18,000<br/> <math>(100,000/62.5) * (GCTL[31:19]) * \text{actual suspend\_clk\_period}</math> should be between 100,000 and 150,000</p> <p>For example, if your suspend_clk frequency varies from 7.5 MHz to 10.5MHz, then the value needs to programmed is:</p> <p>Power Down Scale = <math>10500/16 = 657</math> (rounded up; and fastest frequency used)</p> |
| 18             | R/W        | 0x0         | <p>MASTERFILTBYPASS</p> <p>Master Filter Bypass</p> <p>When this bit is set to 1'b1, irrespective of the parameter USB3_EN_BUS_FILTERS chosen, all the filters in the usb3_filter module will be bypassed.</p> <p>The double synchronizers to mac_clk preceding the filters will also be bypassed. For enabling the filters, this bit should be 1'b0.</p>                                                                                                                                                                                        |
| 17             | R/W        | 0x0         | <p>BYPSETADDR</p> <p>Bypass SetAddress in Device Mode</p> <p>When BYPSETADDR bit is set, the device core uses the value in DCFG[DevAddr] bits directly for comparing the device address in the tokens.</p> <p>For simulation, this feature can be used to avoid sending an actual SET ADDRESS control transfer on the USB to make the device core respond to a new address.</p> <p>Note: This bit must be set for simulation purposes only. In the real hardware, this bit must be set to 1'b0.</p>                                              |
| 16             | R/W        | 0x1         | <p>U2RSTECN</p> <p>If the super speed connection fails during POLL or LMP exchange, the device connects at non-SS mode.</p> <p>If this bit is set, then device attempts three more times to connect at SS, even if it previously failed to operate in SS mode.</p>                                                                                                                                                                                                                                                                               |
| 15:14          | R/W        | 0x0         | <p>FRMSCLDWN</p> <p>This field scales down device view of a</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Offset: 0xC110 |            |             | Register Name: GCTL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                |            |             | SOF/USOF/ITP duration.<br>For SS/HS mode:<br>Value of 2'h3 implements interval to be 15.625 us<br>Value of 2'h2 implements interval to be 31.25 us<br>Value of 2'h1 implements interval to be 62.5 us<br>Value of 2'h0 implements interval to be 125us<br>For FS mode, the scale-down value is multiplied by 8.                                                                                                                                                                                                                                                                                                                     |
| 13:12          | R/W        | 0x02        | PrtCapDir<br>Port Capability Direction<br><ul style="list-style-type: none"> <li>• 2'b01: for Host configurations</li> <li>• 2'b10: for Device configurations</li> <li>• 2'b00, 2'b11: not support</li> </ul> <p><b>Note:</b> For static Host-only or Device-only applications, use DRD Host or DRD Device mode.</p>                                                                                                                                                                                                                                                                                                                |
| 11             | R/W        | 0x0         | CoreSoftReset<br>Core Soft Reset<br>1'b0 - No soft reset<br>1'b1 - Soft reset to core<br>Clears the interrupts and all the CSRs except the following registers:<br><ul style="list-style-type: none"> <li>- GCTL</li> <li>- GUCTL</li> <li>- GSTS</li> <li>- GPIO</li> <li>- GUID</li> <li>- GUSB2PHYCFGn registers</li> <li>- GUSB3PIPECTLn registers</li> <li>- DCFG</li> <li>- DCTL</li> <li>- DEVREN</li> <li>- DSTS</li> </ul> <p>When you reset PHYs (using GUSB3PHYCFG or GUSB3PIPECTL registers), you must keep the core in reset state until PHY clocks are stable. This controls the bus, ram, and mac domain resets.</p> |
| 10             | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 9              | R/W        | 0x0         | U1U2TimerScale<br>Disable U1/U2 timer Scaledown<br>If set to '1' along with GCTL[5:4] (ScaleDown) = 2'bX1 disables the scale down of U1/U2 inactive timer                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

| Offset: 0xC110 |            |             | Register Name: GCTL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                |            |             | values. This is for simulation mode only.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 8              | R/W        | 0x0         | <p>DebugAttach<br/>Debug Attach<br/>When this bit is set:</p> <ul style="list-style-type: none"> <li>• SS Link proceeds directly to the Polling link state (after RUN/STOP in the DCTL register is asserted) without checking remote termination.</li> <li>• Link LFPS polling timeout is infinite</li> <li>• Polling timeout during TS1 is infinite (in case link is waiting for TXEQ to finish).</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 7:6            | R/W        | 0x0         | <p>RAMClkSel<br/>RAM Clock Select<br/>2'b00: bus clock<br/>2'b01: pipe clock<br/>2'b10: In device mode, pipe/2 clock.<br/>2'b11: In device mode, selects mac2_clk as ram_clk when 8-bit UTMI or ULPI is used. (Not supported in 16-bit UTMI mode)</p> <p>In device mode, upon a USB reset and USB disconnect, the hardware clears these bits to 2'b00.</p> <p>Note:<br/>In device mode, if you set RAMClkSel to 2'b11 (mac2_clk), the controller internally switches the ram_clk to bus_clk when the link state changes to Suspend (L2 or L3), and switches the ram_clk back to mac2_clk when the link state changes to resume or U2.<br/>In host mode, this register field setting should not be modified.<br/>A value of 2 can be chosen only if the pipe data width is 8 or 16 bits. In this case the when the ram_clk is switched to pipe_clk, it uses pipe_clk/2 instead of pipe_clk. If a value of 3 is chosen for RAMClkSel, then when ram_clk is switched to pipe_clk, then pipe_clk is used without any divider.<br/>In device mode, when RAMClkSel != 2'b00, the bus_clk_early frequency can be a minimum of 1 MHz. This is tested in simulation and also in hardware with Linux, Microsoft Windows 8, and MCCI Windows7 host drivers. Only control and non</p> |

| Offset: 0xC110 |            |             | Register Name: GCTL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                |            |             | <p>periodic transfers are supported when bus_clk is 1 MHz. For periodic applications, the bus_clk_early minimum frequency is higher depending on your application and SoC bus. Even though 1 MHz has been tested with standard host drivers, Synopsys recommends 5 MHz minimum for ASIC designs to provide a margin or at least have a backup option to increase the bus_clk frequency to 5 MHz if needed.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 5:4            | R/W        | 0x0         | <p>ScaleDown<br/>Scale-Down Mode<br/>When Scale-Down mode is enabled for simulation, the core uses scaled-down timing values, resulting in faster simulations. When Scale-Down mode is disabled, actual timing values are used. This is required for hardware operation.</p> <p>HS/FS/LS Modes<br/>2'b00: Disables all scale-downs. Actual timing values are used.<br/>2'b01: Enables scale-down of all timing values except Device mode suspend and resume.<br/>These include:<br/> <ul style="list-style-type: none"> <li>- Speed enumeration</li> <li>- HNP/SRP</li> <li>- Host mode suspend and resume</li> </ul> 2'b10: Enables scale-down of Device mode suspend and resume timing values only.<br/>2'b11: Enables bit 0 and bit 1 scale-down timing values.</p> <p>SS Mode<br/>2'b00: Disables all scale-downs. Actual timing values are used.<br/>2'b01: Enables scaled down SS timing and repeat values including:<br/> <ul style="list-style-type: none"> <li>- Number of TxEq training sequences reduce to 8</li> <li>- LFPS polling burst time reduce to 100 nS</li> <li>- LFPS warm reset receive reduce to 30 uS.</li> <li>- Refer to the rtl_vip_scaledown_mapping.xls file under &lt;workspace&gt;/sim/SoC_sim directory for the complete list.</li> </ul> </p> |

| Offset: 0xC110 |            |             | Register Name: GCTL                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                    |
|                |            |             | 2'b10: No TxEq training sequences are sent.<br>Overrides Bit 4.<br>2'b11: Enables bit 0 and bit 1 scale-down timing values.                                                                                                                                                                                                                                    |
| 3              | R/W        | 0x0         | DisScramble<br>Disable Scrambling<br>Transmit request to Link Partner on next transition to Recovery or Polling.                                                                                                                                                                                                                                               |
| 2              | R/W        | 0x1         | U2EXIT_LFPS<br>If this bit is,<br>0: the link treats 248ns LFPS as a valid U2 exit.<br>1: the link waits for 8μs of LFPS before it detects a valid U2 exit.                                                                                                                                                                                                    |
| 1              | R          | 0x0         | GblHibernationEn<br>This bit enables hibernation at the global level. If hibernation is not enabled via this bit, the PMU immediately accepts the D0->D3 and D3->D0 power state change requests, but does not save or restore any core state. In addition, the PMUs will never drive the PHY interfaces and let the core continue to drive the PHY interfaces. |
| 0              | R/W        | 0x0         | DsblClkGtng<br>Disable Clock Gating<br>When this bit is set to 1 and the core is in Low Power mode, internal clock gating is disabled. You can set this bit to 1'b1 after Power On Reset.                                                                                                                                                                      |

#### 8.11.6.6 0xC114 Global Power Management Status Register (Default Value:0x0000\_0000)

| Offset: 0xC114 |            |             | Register Name: GPMSTS                                                                                                                                                                                     |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                               |
| 31:28          | W          | 0x0         | PortSel<br>This field selects the port number                                                                                                                                                             |
| 27:17          | /          | /           | /                                                                                                                                                                                                         |
| 16:12          | R          | 0           | U3Wakeups<br>This field gives the following USB 3.1 port wakeup conditions:<br>Bit [12]: Overcurrent Detected<br>Bit [13]: Resume Detected<br>Bit [14]: Connect Detected<br>Bit [15]: Disconnect Detected |

| Offset: 0xC114 |            |             | Register Name: GPMSTS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                |            |             | Bit [16]: Last Connection State                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 11:10          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 9:0            | R          | 0x0         | <p>U2Wakeup<br/>           This field indicates the following USB 2.0 port wakeup conditions:<br/>           Bit [0]: Overcurrent Detected<br/>           Bit [1]: Resume Detected<br/>           Bit [2]: Connect Detected<br/>           Bit [3]: Disconnect Detected<br/>           Bit [4]: Last Connection State<br/>           Bit [5]: ID Change Detected<br/>           Bit [6]: SRP Request Detected<br/>           Bit [7]: ULPI Interrupt Detected<br/>           Bit [8]: USB Reset Detected<br/>           Bit [9]: Resume Detected Changed</p> |

#### 8.11.6.7 0xC118 Global Status Register (Default Value:0x7E80\_0002)

| Offset: 0xC118 |            |             | Register Name: GSTS                                                                                                                                                                                                              |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                      |
| 31:20          | R          | 0x7e8       | <p>CBELT<br/>           Current BELT Value<br/>           In Host mode, this field indicates the minimum value of all received device BELT values and the BELT value that is set by the Set Latency Tolerance Value command.</p> |
| 19:8           | /          | /           | /                                                                                                                                                                                                                                |
| 7              | R          | 0           | <p>Host_IP<br/>           Host Interrupt Pending<br/>           This field indicates that there is a pending interrupt pertaining to xHC in the Host event queue.</p>                                                            |
| 6              | R          | 0           | <p>Device_IP<br/>           Device Interrupt Pending<br/>           This field indicates that there is a pending interrupt pertaining to peripheral (device) operation in the Device event queue.</p>                            |
| 5              | R/W1C      | 0           | <p>CSRTTimeout<br/>           CSR Timeout<br/>           When this bit is 1'b1, it indicates that software performed a write or read to a core register that could not be completed within</p>                                   |

| Offset: 0xC118 |            |             | Register Name: GSTS                                                                                                                                         |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                 |
|                |            |             | ` DWC_USB3_CSR_ACCESS_TIMEOUT bus clock cycles<br>(default: 65535).                                                                                         |
| 4              | R/W1C      | 0           | BusErrAddrVld<br>Bus Error Address Valid<br>Indicates that the GBUSERRADDR register is valid and reports the first bus address that encounters a bus error. |
| 3:2            | /          | /           | /                                                                                                                                                           |
| 1:0            | R          | 0x02        | CurMod<br>Current Mode of Operation<br>Indicates the current mode of operation:<br>2'b00: Device mode<br>2'b01: Host mode                                   |

#### 8.11.6.8 0xC11C Global User Control Register 1 (Default Value: 0x0000\_1988)

| Offset: 0xC11C |            |             | Register Name: GUCTL1                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 31             | R/W        | 0x0         | DEV_DECUPLE_L1L2_EVT<br>Enable this bit if you want to use L1 (LPM) events separately and not combine it with L2 events when operating in USB 2.0 speeds.<br>0: L1 and L2 events (suspend and resume) are not separated. For both L1 and L2 events, common suspend and resume events are generated.<br>1: L1 and L2 events are separated when operating in USB 2.0 mode. For L1 and L2 events, separate suspend and resume events are generated. |
| 30             | R/W        | 0x0         | DS_RXDET_MAX_TOUT_CTRL<br>This bit is used to control the tRxDetectTimeoutDFP timer for the Enhanced SuperSpeed link.<br>0: 12ms is used as tRxDetectTimeoutDFP<br>1: 120ms is used as the tRxDetectTimeoutDFP<br>This bit is used only in host mode. For more details, refer to the <i>USB 3.1 Specification</i> .                                                                                                                              |
| 29             | R/W        | 0x0         | FILTER_SE0_FSL_S_EOP<br>0: Single sampling (utmi/ulpi clock) of linestate is                                                                                                                                                                                                                                                                                                                                                                     |

| Offset: 0xC11C |            |             | Register Name: GUCTL1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                |            |             | <p>checked for SE0 detection.</p> <p>1: Feature enabled; Two samplings of linestate are checked for SE0 detection</p> <p>This bit is applicable for FS/LS operation. If this feature is enabled, SE0 on the linestate is validated for two consecutive utmi/ulpi clock edges for EOP detection. This feature is applicable only in FS in device mode and FS/LS mode of operation in host mode.</p> <p>Device mode (FS): If GUCTL1.FILTER_SE0_FSLS_EOP is set, then for device LPM handshake, the controller ignores single SE0 glitch on the linestate during transmit. Only two or more SE0 is considered as a valid EOP on FS port.</p> <p>Host mode (FS/LS): If GUCTL1.FILTER_SE0_FSLS_EOP is set, then the controller ignores single SE0 glitch on the linestate during transmit. Only two or more SE0 is considered as a valid EOP on FS/LS port.</p> <p>Enable this feature if linestate has SE0 glitches during transmission. This bit is quasi-static, that is, it must not be changed during operation.</p> |
| 28             | R/W        | 0x0         | <p>TX_IPGAP_LINECHECK_DIS</p> <p>0: The linestate transitioning from J to idle for HS mode treated as end of current packet.</p> <p>1: Feature enabled; For detecting the HS end of packet, a fixed delay is used instead of linestate transition.</p> <p>This bit is applicable for HS operation of U2MAC. If this feature is enabled, then the 2.0 MAC operating in HS ignores the UTMI/ULPI linestate during transmission of a token (during token-to-token and token-to-data IPGAP). When enabled, the controller implements a fixed 40-bit TxEndDelay after the packet is given on UTMI and ignores the linestate during this time. This feature is applicable only in HS mode of operation.</p> <p>Device mode: If GUCTL1.TX_IPGAP_LINECHECK_DIS is set, then</p>                                                                                                                                                                                                                                              |

| Offset: 0xC11C |            |             | Register Name: GUCTL1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                |            |             | <p>for device LPM handshake, the controller ignores the linestate after TX and waits for a fixed number of clocks (40 bit times equivalent) after transmitting ACK on utmi.</p> <p>Host mode: If GUCTL1.TX_IPGAP_LINECHECK_DIS is set, then the ipgap (between token to token/data) is added by 40 bit times of TXENDDELAY, and linestate is ignored during this 40 bit times delay. Enable this bit if linestate does not reflect the expected line state (J) during transmission. This bit is quasi-static, that is, it must not be changed during operation.</p>                                                                                                                                                                                                         |
| 27             | R/W        | 0x0         | <p>DEV_TRB_OUT_SPR_IND<br/>         0: Feature disabled; OUT TRB status does not set the Short Packet received bit<br/>         1: Feature enabled; OUT TRB status indicates Short Packet</p> <p>This bit is applicable for device mode only (and ignored in host mode). This feature can be enabled if the device application (software/hardware) wants to know whether a short packet is received for an OUT in the TRB status itself, so that a bit is set in the TRB writeback in the buf_size dword. Bit[26] - SPR of the {trbstatus, RSVD, SPR, PCM1, bufsiz} dword will be set during an OUT transfer TRB write back if this is the last TRB used for that transfer descriptor. This bit is quasi-static, that is, it must not be changed during device operatio</p> |
| 26:25          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 24             | R/W        | 0x0         | <p>DEV_L1_EXIT_BY_HW<br/>         0: Disables device L1 hardware exit logic<br/>         1: Feature enabled</p> <p>This bit is applicable for device mode (2.0) only. This field enables device controller sending remote wakeup for L1 if the device becomes ready for sending/accepting data when in L1 state. If the host expects the device to send remote wakeup signaling to resume after going</p>                                                                                                                                                                                                                                                                                                                                                                   |

| Offset: 0xC11C |            |             | Register Name: GUCTL1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                |            |             | <p>into L1 in flow controlled state, then this bit can be set to send the remote wake signal automatically when the device controller becomes ready. This hardware remote wake feature is applicable only to bulk and interrupt transfers, and not for Isoch/Control</p> <p>When control transfers are in progress, the LPM will be rejected (NYET response). Only after control transfers are completed (either with ACK/STALL), LPM will be accepted</p> <p>For Isoch transfers, the host needs to do the wake-up and start the transfer. Device controller will not do remote-wakeup when Isoch endpoints get ready. The device SW needs to keep the GUSB2PHYCFG[EnblSlpM] reset in order to keep the PHY clock to be running for keeping track of SOF intervals.</p> <p>When L1 hibernation is enabled, the controller will not do automatic exit for hibernation requests through L1.</p> <p>This bit is quasi-static, it must not be changed during device operation.</p> |
| 23:21          | R/W        | 0x0         | <p>IP_GAP_ADD_ON</p> <p>This register field is used to add on to the default inter packet gap setting in the USB 2.0 MAC. It should be programmed to a non-zero value only in case where you need to increase the default inter packet delay calculations in the USB 2.0 MAC module \${ldsg}_u2mac.v The inter packet delay is increased by number of utmi/ulpi clock cycles of this field value.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 20:15          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 14             | R/W        | 0x0         | <p>HW_LPM_CAP_DISABLE</p> <p>Disable hardware LPM capability in the xHCI capability register.</p> <p>When set, it disables hardware LPM capability in xHCI capability register.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 13             | R/W        | 0x0         | <p>HW_LPM_HLE_DISABLE</p> <p>Disable hardware LPM function in all USB 2.0 ports.</p> <p>When set, it disables hardware LPM function in</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

| Offset: 0xC11C |            |             | Register Name: GUCTL1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                |            |             | all USB 2.0 ports.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 12             | R          | 0x1         | <p>DisUSB2RefClkGtng<br/>         Disable ref_clk gating for USB 2.0 PHY<br/>         (DisUSB2RefClkGtng)</p> <p>If ref_clk gating is disabled, then the ref_clk input cannot be turned off to the USB 2.0 PHY and controller. This is independent of the GCTL[DisClkGtng] setting.</p> <p>1'b0: ref_clk gating enabled for USB 2.0 PHY<br/>         1'b1: ref_clk gating disabled for USB 2.0 PHY</p>                                                                                                           |
| 11             | R          | 0x1         | <p>DisRefClkGtng<br/>         Disable ref_clk gating (DisRefClkGtng)</p> <p>If the ref_clk gating is disabled then input ref_clk cannot be turned off to SSPHY and controller.</p> <p>This is independent of GCTL[DisClkGtng] setting.</p> <p>1'b0: ref_clk gating Enabled for SSPHY<br/>         1'b1: ref_clk gating Disabled for SSPHY</p>                                                                                                                                                                    |
| 10             | R/W        | 0x0         | <p>RESUME_OPMODE_HS_HOST<br/>         This bit is used only in host mode, and is for 2.0 opmode behaviour in HS Resume.</p> <p>When this bit is set to '1', the utmi/ulpi opmode will be changed to "normal" along with HS terminations after EOR. This is to support certain legacy UTMI/ULPI PHYs.</p> <p>When this bit is set to '0', the utmi/ulpi opmode will be changed to "normal" 2us after HS terminations change after EOR.</p>                                                                        |
| 9              | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 8              | R/W        | 0x1         | <p>L1_SUSP_THRLD_EN_FOR_HOST<br/>         This bit is used only in host mode.</p> <p>The host controller asserts the utmi_l1_suspend_n and utmi_sleep_n output signals as follows:</p> <p>The controller asserts the utmi_l1_suspend_n signal to put the PHY into deep low-power mode in L1 when both of the following are true:</p> <p>The device accepted BESL/BESLD value is greater than or equal to the value in L1_SUSP_THRLD_FOR_HOST field.</p> <p>The L1_SUSP_THRLD_EN_FOR_HOST bit is set to 1'b1.</p> |

| Offset: 0xC11C |            |             | Register Name: GUCTL1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                |            |             | <p>The controller asserts utmi_sleep_n on L1 when one of the following is true:</p> <p>The device accepted BESL/BESLD value is less than the value in L1_SUSP_THRLD_FOR_HOST field.</p> <p>The L1_SUSP_THRLD_EN_FOR_HOST bit is set to 1'b0.</p>                                                                                                                                                                                                                                                      |
| 7:4            | R/W        | 0x8         | <p>L1_SUSP_THRLD_FOR_HOST</p> <p>This field is effective only when the L1_SUSP_THRLD_EN_FOR_HOST bit is set to 1. For more details, refer to the description of the L1_SUSP_THRLD_EN_FOR_HOST bit.</p> <p>Note: Program this register field based on the UTMI/ULPI wakeup time in L1 suspend/sleep. In addition, for PCIe-based implementation, consider the DBESLD register value also.</p>                                                                                                          |
| 3              | R/W        | 0x1         | <p>HC_ERRATA_ENABLE</p> <p>Host ELD Enable (HELDEn)</p> <p>When this bit is set to 1, it enables the Exit Latency Delta (ELD) support defined in the xHCI 1.1.</p> <p>This bit is used only in the host mode. This bit has to be set to 1 in Host mode.</p>                                                                                                                                                                                                                                           |
| 2              | R/W        | 0x0         | <p>HC_PARCHK_DISABLE</p> <p>Host Parameter Check Disable (HParChkDisable)</p> <p>When this bit is set to '0', the xHC checks that the input slot/EP context fields comply to the <i>xHCI Specification</i>. Upon detection of a parameter error during command execution, the xHC generates an event TRB with completion code indicating 'PARAMETER ERROR'.</p> <p>When the bit is set to '1', the xHC does not perform parameter checks and does not generate 'PARAMETER ERROR' completion code.</p> |
| 1              | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0              | R/W        | 0x0         | <p>LOA_FILTER_EN</p> <p>If this bit is set, the USB 2.0 port babble is checked at least three consecutive times before the port is disabled. This prevents false triggering of the babble condition when using low quality cables.</p>                                                                                                                                                                                                                                                                |

#### 8.11.6.9 0xC120 Global ID Register (Default Value: 0x3331\_3130)

| Offset: 0xC120 |            |             | Register Name: GID |
|----------------|------------|-------------|--------------------|
| Bit            | Read/Write | Default/Hex | Description        |
| 31:0           | R          | 0x33313130  | ID                 |

#### 8.11.6.10 0xC124 Global General Purpose Input/Output Register (Default Value: 0x0000\_0000)

| Offset: 0xC124 |            |             | Register Name: GPIO                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                           |
| 31:16          | R/W        | 0           | GPO<br>General Purpose Output<br>This field's value is driven out on the gp_o[15:0] core output port. |
| 15:0           | R          | 0           | GPI<br>General Purpose Input<br>This field's read value reflects the gp_i[15:0] core input value.     |

#### 8.11.6.11 0xC128 Global User ID Register (Default Value: 0x1234\_5678)

| Offset: 0xC128 |            |             | Register Name: GUID                          |
|----------------|------------|-------------|----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                  |
| 31:0           | R/W        | 0x12345678  | UserID<br>Application-programmable ID field. |

#### 8.11.6.12 0xC12C Global User Control Register (Default Value: 0x0A41\_6802)

| Offset: 0xC12C |            |             | Register Name: GUCTL                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                    |
| 31:22          | R/W        | 0x29        | REFCLKPER<br>This field indicates the period of ref_clk, in terms of nano seconds.<br>The valid programmable values of this field are as follows:<br>'h19: 25ns (integer corresponding to the supported ref_clk frequencies of 39.7 MHz)<br>'h29: 41ns (integer corresponding to the supported ref_clk frequency of 24 MHz)<br>'h32: 50ns (integer corresponding to the supported ref_clk frequency of 20 MHz) |

| Offset: 0xC12C |            |             | Register Name: GUCTL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                |            |             | <p>'h34: 52ns (integer corresponding to the supported ref_clk frequency of 19.2MHz)</p> <p>'h3A: 58ns (integer corresponding to the supported ref_clk frequency of 17 MHz)</p> <p>'h3E: 62ns (integer corresponding to the supported ref_clk frequency of 16 MHz)</p> <p>This field needs to be updated during power-on initialization.</p>                                                                                                                                                                                                                                                                                                                                                                                                 |
| 21             | R/W        | 0           | <p>NoExtrDI</p> <p>No Extra Delay Between SOF and the First Packet</p> <p>Some HS devices misbehave when the host sends a packet immediately after a SOF. However, adding an extra delay between a SOF and the first packet can reduce the USB data rate and performance.</p> <p>This bit is used to control whether the host should wait for 2 microseconds before it sends the first packet after a SOF, or not. User can set this bit to one to improve the performance if those problematic devices are not a concern in the user's host environment.</p> <p>1'b0: Host waits for 2 microseconds after a SOF before it sends the first USB packet.</p> <p>1'b1: Host doesn't wait after a SOF before it sends the first USB packet.</p> |
| 20             | R/W        | 0x0         | DMAIgnoreHCE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 19             | R/W        | 0x0         | IgnoreHCETimeout                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 18             | R/W        | 0x0         | <p>EN_EXTD_TBC_CAP</p> <p>When set, the Extended TBC Capability is reported in HCCPARAMS2 if the DWC_USB31_EXTD_TBC_CAP_EN parameter is enabled.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 17             | R/W        | 0           | <p>SprsCtrlTransEn</p> <p>Sparse Control Transaction Enable</p> <p>Some devices are slow in responding to Control transfers. Scheduling multiple transactions in one microframe/frame can cause these devices to misbehave. If this bit is set to 1'b1, the host controller schedules transactions for a Control transfer in different microframes/frames.</p>                                                                                                                                                                                                                                                                                                                                                                              |
| 16             | R/W        | 0           | ResBwHSEPS<br>Reserving 85% Bandwidth for HS Periodic EPs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

| Offset: 0xC12C |            |             | Register Name: GUCTL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                |            |             | <p>1'b0: HC reserves 80% of the bandwidth for periodic EPs.</p> <p>1'b1: HC relaxes the bandwidth to 85% to accommodate two high-speed high-bandwidth ISOC EPs.</p> <p>USB 2.0 required 80% bandwidth allocated for ISOC traffic. If two high-bandwidth ISOC devices (HD Webcams) are connected and each device requires 1024-bytes X 3 packets per micro-frame, then the bandwidth required is around 82%. If this bit is set, then it is possible to connect two Webcams of 1024bytes X 3 payload per micro-frame each.</p> <p>Otherwise, you may have to reduce the resolution of the Webcams.</p> <p>This bit is valid in Host mode operation only. This field is ignored for device mode.</p> |
| 15             | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 14             | R/W        | 0           | <p>USBHstInAutoRetryEn</p> <p>Host IN Immediate Retry</p> <p>When set, this field enables the Immediate Retry feature. For IN transfers (non-isochronous) that encounter data packets with CRC errors or internal overrun scenarios, the immediate retry feature causes the Host controller to reply to the device with a non-terminating retry ACK (that is, an ACK transaction packet with Retry = 1 and NumP != 0). If the Immediate Retry feature is disabled, the controller will respond with a terminating retry ACK (that is, an ACK transaction packet with Retry = 1 and NumP = 0).</p> <p>1'b0: Immediate Retry Disabled</p> <p>1'b1: Immediate Retry Enabled</p>                       |
| 13             | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 12             | R/W        | 0x0         | <p>ExtCapSuptEN</p> <p>External Extended Capability Support Enable</p> <p>When set, this field enables extended capabilities to be implemented outside the controller.</p> <p>When the ExtCapSupEN is set and the Debug Capability is enabled, the Next Capability pointer in "Debug Capability" returns 16.</p> <p>A read to the first DWORD of the last internal</p>                                                                                                                                                                                                                                                                                                                             |

| Offset: 0xC12C |            |             | Register Name: GUCTL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                |            |             | <p>extended capability (the "xHCI Supported Protocol Capability for USB 3.1" when the Debug Capability is not enabled) returns a value of 4 in the Next Capability Pointer field.</p> <p>This indicates to software that there is another capability four DWORDS after this capability (for example, at address N+16 where N is the address of this DWORD). If enabled, an external address decoder that snoops the xHC slave interface must be implemented. If it sees an access to N+16 or greater, the slave access is re-routed to a piece of hardware which returns the external capability pointer register of the new capability and also handles reads/writes to this new capability and the side effects.</p> <p>If disabled, a read to the first DWORD of the last internal extended capability returns 0 in the 'Next Capability Pointer field. This indicates there are no more capabilities.</p> |
| 11             | R/W        | 0           | <p>InsrtExtrFSBODI<br/>Insert Extra Delay Between FS Bulk OUT Transactions</p> <p>Some FS devices are slow to receive Bulk OUT data and can get stuck when there are consecutive Bulk OUT transactions with short inter-transaction delays. This bit is used to control whether the host inserts extra delay between consecutive Bulk OUT transactions to a FS Endpoint.</p> <p>1'b0: Host doesn't insert extra delay between consecutive Bulk OUT transactions to a FS Endpoint.<br/>1'b1: Host inserts about 12us extra delay between consecutive Bulk OUT transactions to a FS Endpoint to work around the device issue.</p> <p><b>Note:</b> Setting this bit to one will reduce the Bulk OUT transfer performance for FS devices.</p>                                                                                                                                                                     |
| 10:0           | R/W        | 0x2         | <p>DTOUT<br/>Device Timeout (DTOUT) This field is Host mode parameter which determines how long the host waits for response from Enhanced SuperSpeed Device before considering the transaction to be timeout. Each count indicates duration in terms of 125us. For example a value of 1 indicates timeout at</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

| Offset: 0xC12C |            |             | Register Name: GUCTL                                                                                                                                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                           |
|                |            |             | the minimum of 125us and maximum of 250us. The maximum value that can be programmed is 200 which sets 25ms as timeout time (minimum is 25ms and maximum is 25.125ms). |

#### 8.11.6.13 0xC130 Global Bus Error Address Low Register (Default Value:0x0000\_0000)

| Offset: 0xC130 |            |             | Register Name: GBUSERRADDLR                                                                                                                                                                                    |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                    |
| 31:0           | R          | 0x0         | BusAddrLo<br>This register contains the lower 32 bits of the first bus address that encountered a bus error. It is valid when the GSTS.BusErrAddrVld field is 1. It can only be cleared by resetting the core. |

#### 8.11.6.14 0xC134 Global Bus Error Address High Register (Default Value:0x0000\_0000)

| Offset: 0xC134 |            |             | Register Name: GBUSERRADDHR                                                                                                                                                                                     |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                     |
| 31:0           | R          | 0x0         | BusAddrHi<br>This register contains the higher 32 bits of the first bus address that encountered a bus error. It is valid when the GSTS.BusErrAddrVld field is 1. It can only be cleared by resetting the core. |

#### 8.11.6.15 0xC138 Global Super Speed Port to Bus Instance Mapping Low Register (Default Value:0x0000\_0000)

| Offset: 0xC138 |            |             | Register Name: GPRTBIMAPLO                                                     |
|----------------|------------|-------------|--------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                    |
| 31:4           | /          | /           | /                                                                              |
| 3:0            | R/W        | 0x0         | BINum1<br>SS USB Instance Number for Port 1 Application-programmable ID field. |

#### 8.11.6.16 0xC13C Global Super Speed Port to Bus Instance Mapping High Register (Default Value:0x0000\_0000)

|                |                            |
|----------------|----------------------------|
| Offset: 0xC13C | Register Name: GPRTBIMAPHI |
|----------------|----------------------------|

| Bit  | Read/Write | Default/Hex | Description |
|------|------------|-------------|-------------|
| 31:0 | /          | /           | /           |

#### 8.11.6.17 0xC160 Global Debug Queue/FIFO Space Available Register (Default Value: 0x0042\_0000)

| Offset: 0xC160 |            |             | Register Name: GDBDFIFOSPACE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 31:16          | R          | 0x43        | Space Available                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 15:9           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 8:0            | R/W        | 0x0         | <p>FIFO_Queue_Select</p> <ul style="list-style-type: none"> <li>"FIFO/Queue Select[8:5] indicates the FIFO/Queue Type</li> <li>"FIFO/Queue Select[4:0] indicates the FIFO/Queue Number</li> </ul> <p>For example, 9'b0_0010_0001 refers to RxFIFO_1 and 9'b0_0101_1110 refers to TxReqQ_30.</p> <p>9'b0_0001_1111 to 9'b0_0000_0000: TxFIFO_31 to TxFIFO_0</p> <p>9'b0_0011_1111 to 9'b0_0010_0000: RxFIFO_31 to RxFIFO_0</p> <p>9'b0_0101_1111 to 9'b0_0100_0000: TxReqQ_31 to TxReqQ_0</p> <p>9'b0_0111_1111 to 9'b0_0110_0000: RxReqQ_31 to RxReqQ_0</p> <p>9'b0_1001_1111 to 9'b0_1000_0000: RxInfoQ_31 to RxInfoQ_0</p> <p>9'b0_1010_0000: DescFetchQ_0 (for backwards compatibility)</p> <p>9'b0_1010_0001: EventQ_0 (for backwards compatibility)</p> <p>9'b0_1010_0010: ProtocolStatusQ_0</p> <p>9'b0_1101_1111 to 9'b0_1110_0000: DescFetchQ_31 to DescFetchQ_0</p> <p>9'b0_1111_1111 to 9'b0_1110_0000: WriteBack/EventQ_31 to WriteBack/EventQ_0</p> <p>9'b1_0000_0111 to 9'b1_0000_0000: AuxEventQ_7 to AuxEventQ_0 (if EN_SEPARATE_DESC_QUEUES=1)</p> |

#### 8.11.6.18 0xC164 Global BMU Control Register (Default Value:0x9CC2\_0026)

| Offset: 0xC164 |            |             | Register Name: GBMUCTL |
|----------------|------------|-------------|------------------------|
| Bit            | Read/Write | Default/Hex | Description            |

| Offset: 0xC164 |            |             | Register Name: GBMUCTL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 31:16          | R/W        | 0x9CC2      | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 15:6           | R          | 0x0         | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 5              | R/W        | 0x1         | <p>separate_psq_en</p> <p>When DWC_USB31_EN_SEPARATE_PSQ_PER_DIR is enabled Separate internal process queue and state machine per direction is enabled</p> <p>when the bit is set to ?1?, BMU will process the plr_msg_type[PSQ_DIR] bit and pushes the messages to separate PSQ based on direction including special handling of control endpoint messages.</p> <p>when the bit is set to ?0?, BMU will ignore the plr_msg_type[PSQ_DIR] bit for all message types and pushes the messages to single PSQ to retain the legacy mode of operation.</p> |
| 4:3            | R          | 0x0         | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 2              | R/W        | 0x1         | <p>axi_storder_en</p> <p>When DWC_USB31_AXI_STRICT_ORDER_EN parameter is enabled, both descriptor and data RxDMAs should be configured to use non-posted commands. For a given BI, descriptor/event RxDMA won't be issued until the previous issued data RxDMA is completed on the bus</p>                                                                                                                                                                                                                                                            |
| 1              | R/W        | 0x1         | active_id_en<br>Active Id enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0              | R/W        | 0x0         | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

#### 8.11.6.19 0xC16C Global Debug BMU Register (Default Value:0x0000\_0000)

| Offset: 0xC16C |            |             | Register Name: GDBGBMU    |
|----------------|------------|-------------|---------------------------|
| Bit            | Read/Write | Default/Hex | Description               |
| 31:8           | R          | 0x0         | BMU_BCU Debug information |
| 7:4            | R          | 0x0         | BMU_DCU Debug information |
| 3:0            | R          | 0x0         | BMU_CCU Debug information |

#### 8.11.6.20 0xC170 Global Debug LSP MUX Register (Default Value:0x003F\_0000)

| Offset: 0xC170 |            |             | Register Name: GDBGSPMUX |
|----------------|------------|-------------|--------------------------|
| Bit            | Read/Write | Default/Hex | Description              |
| 31:24          | /          | /           | /                        |

| Offset: 0xC170 |            |             | Register Name: GDBGLSPMUX                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 23:16          | R/W        | 0x3F        | "logic_analyzer_trace" Port MUX Select<br>Currently only bits[21:16] are used.<br>For details on how the mux controls the debug traces, refer to "assign logic_analyzer_trace =" code section in the usb31.v file.<br>A value of 6'h3F drives "0"s on the logic_analyzer_trace signal. If you plan to OR (instead using a mux) this signal with other trace signals in your system to generate a common trace signal, you can use this feature.                                                 |
| 15             | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 14:0           | R/W        | 0x0         | LSP Select<br>In host mode:<br>[14:0] - Selects the LSP debug information presented in the GDBGLSP register.<br>In device mode:<br>[3:0] - Device Endpoint Select (EPSELECT)<br>Selects the Endpoint debug information presented in the GDBGEPIINFO registers in device mode<br>[7:4] - Device LSP Select (DEVSELECT)<br>Selects the LSP debug information presented in the GDBGLSP register<br>[14:8] - Host LSP Select<br>Selects the LSP debug information presented in the GDBGLSP register |

#### 8.11.6.21 0xC174 Global Debug LSP Register (Default Value:0x0000\_0000)

| Offset: 0xC174 |            |             | Register Name: GDBGLSP                                           |
|----------------|------------|-------------|------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                      |
| 31: 0          | R          | 0           | LSP Debug Information<br>This register is for internal use only. |

#### 8.11.6.22 0xC178 Global Debug Endpoint Information Register 0 (Default Value:0x0000\_0000)

| Offset: 0xC178 |            |             | Register Name: GDBEPIINFO0                                                         |
|----------------|------------|-------------|------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                        |
| 31:0           | R          | 0x0         | Endpoint Debug Information, bits [31:0]<br>This register is for internal use only. |

#### 8.11.6.23 0xC17C Global Debug Endpoint Information Register 1 (Default Value:0x0000\_0000)

| Offset: 0xC17C |            |             | Register Name: GDBGEPIINFO1                                                         |
|----------------|------------|-------------|-------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                         |
| 31:0           | R/W        | 0x0         | Endpoint Debug Information, bits [63:32]<br>This register is for internal use only. |

#### 8.11.6.24 0xC180 Global High Speed Port to Bus Instance Mapping Low Register (Default Value:0x0000\_0000)

| Offset: 0xC180 |            |             | Register Name: GPRTBIMAPLR_HS                                                     |
|----------------|------------|-------------|-----------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                       |
| 31:4           | /          | /           | /                                                                                 |
| 3:0            | R/W        | 0           | BINum1<br>HS USB Instance Number for Port 1<br>Application-programmable ID field. |

#### 8.11.6.25 0xC184 Global High Speed Port to Bus Instance Mapping High Register (Default Value:0x0000\_0000)

| Offset: 0xC184 |            |             | Register Name: GPRTBIMAPHR_HS |
|----------------|------------|-------------|-------------------------------|
| Bit            | Read/Write | Default/Hex | Description                   |
| 31:0           | /          | /           | /                             |

#### 8.11.6.26 0xC188 Global Full Speed Port to Bus Instance Mapping Low Register (Default Value:0x0000\_0000)

| Offset: 0xC188 |            |             | Register Name: GPRTBIMAPLR_FS                                                     |
|----------------|------------|-------------|-----------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                       |
| 31:4           | /          | /           | /                                                                                 |
| 3:0            | R/W        | 0x0         | BINum1<br>FS USB Instance Number for Port 1<br>Application-programmable ID field. |

#### 8.11.6.27 0xC18C Global Full Speed Port to Bus Instance Mapping High Register (Default Value:0x0000\_0000)

| Offset: 0xC18C |            |             | Register Name: GPRTBIMAPHR_FS |
|----------------|------------|-------------|-------------------------------|
| Bit            | Read/Write | Default/Hex | Description                   |
| 31:0           | /          | /           | /                             |

#### 8.11.6.28 0xC190 Global Host Mode SoC Bandwidth Override Register (Default Value:0x0000\_0000)

| Offset: 0xC190 |            |             | Register Name: GHMSOCBWOR                                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                            |
| 31             | R/W        | 0x0         | ovrd_port_soc_bw<br>Overrides the SoC bandwidth port values<br>When this field is set 1, the ovrd_soc_common_rd_wr_bus, ovrd_soc_rd_uF_kB_bandwidth, and ovrd_soc_wr_uF_kB_bandwidth register values are used instead common_soc_rd_wr, soc_rd_uF_kB_bandwidth, and soc_wr_uF_kB_bandwidth input ports |
| 30             | R/W        | 0x0         | ovrd_common_soc_rd_wr<br>Override value for the common_soc_rd_wr port<br>1'b0: Separate SoC Bus for Read and Write<br>1'b1: Common SoC Bus for Read and Write                                                                                                                                          |
| 29:15          | R/W        | 0x0         | ovrd_soc_wr_uF_kB_bandwidth<br>SoC Bus Write Bandwidth in KiloBytes/Micro-Frame<br>Override value for the soc_wr_uF_kB_bandwidth port                                                                                                                                                                  |
| 14:0           | R/W        | 0x0         | ovrd_soc_rd_uF_kB_bandwidth<br>SoC Bus Read Bandwidth in KiloBytes/Micro-Frame<br>Override value for the soc_rd_uF_kB_bandwidth port                                                                                                                                                                   |

#### 8.11.6.29 0xC200 Global USB2 PHY Configuration Register (Default Value:0x0000\_2400)

| Offset: 0xC200 |            |             | Register Name: GUSB2PHYCFGn                                                                                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                   |
| 31             | R/W        | 0x0         | PHYSOFRST<br>UTMI PHY Soft Reset<br>Causes the usb2phy_reset signal to be asserted to reset a UTMI PHY. Not applicable to ULPI because ULPI PHYs are reset via their FunctionControl.Reset register, and the core automatically writes to this register when the core is reset (vcc_reset_n, USBCMD.HCRST, DCTL.SoftReset, or GCTL.SoftReset) |
| 30:26          | /          | /           | /                                                                                                                                                                                                                                                                                                                                             |
| 25             | R/W        | 0x0         | OVRD_FSLSDISC_TIME<br>Overriding the FS/LS disconnect time to 32us.<br>If this value is 0, the FS/LS disconnect time is set to                                                                                                                                                                                                                |

| Offset: 0xC200 |            |             | Register Name: GUSB2PHYCFGn                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 24:22          | R/W        | 0x0         | <p>2.5us as per the USB specification. If this value is non-0, then the disconnect detection time is set to 32us.</p> <p>Normally this value is set to 0. But if the 2.0 PHYs introduce noise on UTMI linestate and cause SE0 gliches longer than 2.5us, then a false disconnect condition may get triggered. To avoid interoperability issues with these PHYs, this bit can be set to 1</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 21:19          | R/W        | 0x2         | <p>LSTRD<br/>LS Turnaround Time (LSTRDTIM)</p> <p>This field indicates the value of the Rx-to-Tx packet gap for LS devices. The encoding is as follows:</p> <ul style="list-style-type: none"> <li>0: 2 bit times</li> <li>1: 2.5 bit times</li> <li>2: 3 bit times</li> <li>3: 3.5 bit times</li> <li>4: 4 bit times</li> <li>5: 4.5 bit times</li> <li>6: 5 bit times</li> <li>7: 5.5 bit times</li> </ul> <p><b>Note:</b><br/> <b>This field is applicable only in Host mode.</b><br/> <b>For normal operation (to work with most LS devices), it is recommended to set the value of this field to 3'h0 (2 bit times).</b></p> <p>The programmable LS device inter-packet gap and turnaround delays are provided to support some legacy LS devices that might require different delays than the default/fixed ones. For instance, the AOpen LS mouse requires 3 bit times of inter-packet gap to work correctly.</p> <p>Include your PHY delays when programming the LSIPD/LSTRDTIM values. For example, if your PHY TxEndDelay in LS mode is 30 UTMI/ULPI CLks, then subtract this delay (~1 LS bit time) from the delay requirement of the device.</p> |

| Offset: 0xC200 |            |             | Register Name: GUSB2PHYCFGn                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 18             |            |             | <p>0: 2 bit times<br/> 1: 2.5 bit times<br/> 2: 3 bit times<br/> 3: 3.5 bit times<br/> 4: 4 bit times<br/> 5: 4.5 bit times<br/> 6: 5 bit times<br/> 7: 5.5 bit times</p> <p><b>Note:</b><br/> <b>This field is applicable only in Host mode.</b><br/> <b>For normal operation (to work with most LS devices), it is recommended to set this field to 3'h2 (3 bit times).</b></p> <p>The programmable LS device inter-packet gap and turnaround delays are provided to support some legacy LS devices that might require different delays than the default/fixed ones. For instance, the AOpen LS mouse requires 3 bit times of inter-packet gap to work correctly.</p> <p>Include your PHY delays when programming the LSIPD/LSTRDTIM values. For example, if your PHY TxEndDelay in LS mode is 30 UTMI/ULPI CLKs, then subtract this delay (~1 LS bit time) from the delay requirement of the device.</p> |
| 18             | R/W        | 0x0         | <p>ULPIExtVbusIndicator<br/> ULPI External VBUS Indicator<br/> Indicates the ULPI PHY VBUS over-current indicator.</p> <ul style="list-style-type: none"> <li>• 1'b0: PHY uses an internal VBUS valid comparator.</li> <li>• 1'b1: PHY uses an external VBUS valid comparator.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 17             | R/W        | 0x0         | <p>ULPIExtVbusDrv<br/> ULPI External VBUS Drive<br/> Selects supply source to drive 5V on VBUS, in the ULPI PHY.</p> <ul style="list-style-type: none"> <li>• 1'b0: PHY drives VBUS with internal charge pump (default).</li> <li>• 1'b1: PHY drives VBUS with an external supply.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 16             | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 15             | R/W        | 0x0         | <p>ULPIAutoRes<br/> ULPI Auto Resume<br/> Sets the AutoResume bit in Interface Control register on the ULPI PHY.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

| Offset: 0xC200 |            |             | Register Name: GUSB2PHYCFGn                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                |            |             | <ul style="list-style-type: none"> <li>• 1'b0: PHY does not use the AutoResume feature.</li> <li>• 1'b1: PHY uses the AutoResume feature.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 14             | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 13:10          | R/W        | 0x09        | <p>USBTrdTim<br/>USB 2.0 Turnaround Time<br/>Sets the turnaround time in PHY clocks.<br/>Specifies the response time for a MAC request to the Packet FIFO Controller (PFC) to fetch data from the DFIFO (SPRAM). These following are the required values for the minimum SoC bus frequency of 60 MHz. USB turnaround time is a critical certification criteria when using long cables and five hub levels. The required values for this field:</p> <ul style="list-style-type: none"> <li>• 4'h5: When the MAC interface is 16-bit UTMI+.</li> <li>• 4'h9: When the MAC interface is 8-bit UTMI+.</li> </ul> <p>If SoC bus does not require 60 MHz and USB turnaround time is not critical, this field can be set to a larger value.</p>                     |
| 9              | R/W        | 0x0         | <p>XCVRDLY<br/>Transceiver Delay:<br/>Enables a delay between the assertion of the UTMI/ULPI Transceiver Select signal (for HS) and the assertion of the TxValid signal during a HS Chirp. When this bit is set to 1, a delay (of approximately 2.5 us) is introduced from the time when the Transceiver Select is set to 2'b00 (HS) to the time the TxValid is driven to 1 for sending the chirp-K. This delay is required for some UTMI/ULPI PHYs.</p> <p>Note:<br/>If you enable the hibernation feature when the device controller comes out of power-off, you must re-initialize this bit with the appropriate value because the controller does not save and restore this bit value during hibernation.<br/>This bit is valid only in device mode.</p> |
| 8              | R/W        | 0x0         | <p>EnblSlpM<br/>Enable utmi_sleep_n and utmi_l1_suspend_n<br/>The application uses this bit to control utmi_sleep_n and utmi_l1_suspend_n assertion to the PHY in the</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

| Offset: 0xC200 |            |             | Register Name: GUSB2PHYCFGn                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                |            |             | <p>L1 state.</p> <p>1'b0: utmi_sleep_n and utmi_l1_suspend_n assertion from the core is not transferred to the external PHY.</p> <p>1'b1: utmi_sleep_n and utmi_l1_suspend_n assertion from the core is transferred to the external PHY.</p> <p><b>Note:</b> In Device mode - Before issuing any device endpoint command when operating in 2.0 speeds, disable this bit and enable it after the command completes. Without disabling this bit, if a command is issued when the device is in L1 state and if mac2_clk (utmi_clk/ulpi_clk) is gated off, the command will not get completed.</p>                                                                                                                                                |
| 7              | R/W        | 0x0         | <p>PHYSel</p> <p>USB 2.0 High-Speed PHY or USB 1.1 Full-Speed Serial Transceiver Select</p> <p>The application uses this bit to select a high-speed PHY or a full-speed transceiver.</p> <ul style="list-style-type: none"> <li>• 1'b0: USB 2.0 high-speed UTMI+ or ULPI PHY<br/>This bit is always 0, with Write Only access.</li> <li>• 1'b1: USB 1.1 full-speed serial transceiver<br/>This bit is always 1, with Write Only access.<br/>If both interface types are selected in global (parameters values are not zero), the application uses this bit to select the active interface is active, with Read-Write bit access.</li> </ul> <p>Note: USB 1.1 full-serial transceiver is not supported.<br/>This bit always reads as 1'b0.</p> |
| 6              | R/W        | 0x0         | <p>SusPHY</p> <p>Suspend USB2.0 HS/FS/LS PHY</p> <p>When set, USB2.0 PHY enters Suspend mode if Suspend conditions are valid.</p> <p>For DRD/OTG configurations, it is recommended that this bit is set to '0' during coreConsultant configuration. If it is set to '1', then the application should clear this bit after power-on reset.</p> <p>Application needs to set it to '1' after the core initialization is completed.</p> <p>For all other configurations, this bit can be set to '1' during core configuration.</p>                                                                                                                                                                                                                |

| Offset: 0xC200 |            |             | Register Name: GUSB2PHYCFGn                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                |            |             | <p>Note: In host mode, on reset, this bit is set to '1'. Software can override this bit after reset.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 5              | R/W        | 0x0         | <p>FSIntf<br/>Full-Speed Serial Interface Select<br/>The application uses this bit to select a unidirectional or bidirectional USB 1.1 full-speed serial transceiver interface.</p> <ul style="list-style-type: none"> <li>• 1'b0: 6-pin unidirectional full-speed serial interface<br/>This bit is set to 0 with Read Only access.</li> <li>• 1'b1: 3-pin bidirectional full-speed serial interface<br/>This bit is set to 0 with Read Only access.</li> </ul> <p>Note: USB 1.1 full-speed serial interface is not supported. This bit always reads as 1'b0.</p>                                                                                                                                                                                                                |
| 4              | R/W        | 0x0         | <p>ULPI_UTMI_Sel<br/>ULPI or UTMI+ Select<br/>The application uses this bit to select a UTMI+ or ULPI Interface.</p> <ul style="list-style-type: none"> <li>• 1'b0: UTMI+ Interface</li> <li>• 1'b1: ULPI Interface</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 3              | R/W        | 0x0         | <p>PHYIf<br/>PHY Interface<br/>If UTMI+ is selected, the application uses this bit to configure the core to support a UTMI+ PHY with an 8- or 16-bit interface.</p> <ul style="list-style-type: none"> <li>• 1'b0: 8 bits</li> <li>• 1'b1: 16 bits</li> </ul> <p>If ULPI is selected , this bit is reserved to '0'.</p> <p>Note:<br/>All the enabled 2.0 ports should have the same clock frequency as Port0 clock frequency (utmi_clk[0]). The UTMI 8-bit and 16-bit modes cannot be used together for different ports at the same time (that is, all the ports should be in 8-bit mode, or all of them should be in 16-bit mode, at a time). If any of the USB 2.0 ports is selected as ULPI port for operation, then all the USB 2.0 ports should be operating at 60 MHz.</p> |
| 2:0            | R/W        | 0x0         | <p>TOutCal<br/>HS/FS Timeout Calibration<br/>The number of PHY clocks, as indicated by the application in this field, is multiplied by a bit-time</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

| Offset: 0xC200 |            |             | Register Name: GUSB2PHYCFGn                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                |            |             | <p>factor. This factor is added to the high-speed/full-speed interpacket timeout duration in the core to account for additional delays introduced by the PHY. This may be required, since the delay introduced by the PHY in generating the linestate condition may vary among PHYs. The USB standard timeout value for high-speed operation is 736 to 816 (inclusive) bit times. The USB standard timeout value for full-speed operation is 16 to 18 (inclusive) bit times. The application must program this field based on the speed of connection. The number of bit times added per PHY clock are:</p> <p>High-speed operation:</p> <ul style="list-style-type: none"> <li>• One 30-MHz PHY clock = 16 bit times</li> <li>• One 60-MHz PHY clock = 8 bit times</li> </ul> <p>Full-speed operation:</p> <ul style="list-style-type: none"> <li>• One 30-MHz PHY clock = 0.4 bit times</li> <li>• One 60-MHz PHY clock = 0.2 bit times</li> <li>• One 48-MHz PHY clock = 0.25 bit times</li> </ul> |

#### 8.11.6.30 0xC2C0 Global USB3 PIPE Control Register (Default Value:0x010C\_0002)

| Offset: 0xC2C0 |            |             | Register Name: GUSB3PIPECTLn                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 31             | R/W        | 0x0         | <p>PHYSoftRst</p> <p>PHY soft-reset; to issue PHY reset, software should set this bit and reset this bit after meeting PHY reset timing.</p>                                                                                                                                                                                                                                                                                                                                                                   |
| 30             | R/W        | 0x0         | <p>HstPrtCmpl</p> <p>This feature tests the PIPE PHY compliance patterns without having to have a test fixture on the USB 3.1 cable.</p> <p>This bit enables placing the SS port link into a compliance state. By default, this bit should be set to 1'b0.</p> <p>In compliance lab testing, the SS port link enters compliance after failing the first polling sequence after power on. Set this bit to 0, when you run compliance tests.</p> <p>The sequence for using this functionality is as follows:</p> |

| Offset: 0xC2C0 |            |             | Register Name: GUSB3PIPECTLn                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 29             | R/W        | 0x0         | <p>Disconnect any plugged in devices.</p> <p>Perform USBCMD.HCRST or power-on-chip reset.</p> <p>Set PORTSC.PP=0.</p> <p>Set GUSB3PIPECTL. HstPrtCmpl=1. This places the link into compliance state.</p> <p>To advance the compliance pattern, follow this sequence (toggle the set GUSB3PIPECTL. HstPrtCmpl):</p> <ul style="list-style-type: none"> <li>Set GUSB3PIPECTL.HstPrtCmpl=0.</li> <li>Set GUSB3PIPECTL.HstPrtCmpl=1. This advances the link to the next compliance pattern.</li> </ul> <p>To exit from the compliance state perform USBCMD.HCRST or power-on-chip reset.</p>                                                                                                                                                                                           |
| 28             | R/W        | 0x0         | <p>U2P3ok</p> <p>Enable P3 entry during U2/SSIInactive (U2P3ok). This is not recommended with Synopsys PHY which has P3 exit time of ~1ms and P2 exit time of ~100uS. This is recommended only if your PHYs P3 exit time is close to P2 exit time. Putting the ESS PHY in P3 during U2 would affect ESS Asynchronous endpoint performance and also this could prevent U2 entry if there are ESS periodic endpoints and their BIInterval is in the sub milli-second range. rammer's Guide for more details.</p> <p>0: During link state U2/ESS.Inactive, put PHY in P2 (Default)</p> <p>1: During link state U2/ESS.Inactive, put PHY in P3 (Not recommended for Synopsys PHY).</p> <p>Note: For a port, if GUSB3PIPECTL[7]=1 and GUSB3PIPECTL[29]=1, set GUSB3PIPECTL[11] to 1</p> |
| 27             | R/W        | 0x0         | <p>DisRxDetP3</p> <p>Disabled receiver detection in P3</p> <p>0: If PHY is in P3 and Core needs to perform receiver detection, Core will perform receiver detection in P3</p> <p>1: If PHY is in P3 and Core needs to perform receiver detection, Core will change PHY power state to P2 and then perform receiver detection. After receiver detection, Core will change PHY power state to P3.</p>                                                                                                                                                                                                                                                                                                                                                                                |

| Offset: 0xC2C0 |            |             | Register Name: GUSB3PIPECTLn                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                |            |             | <p>P0 (default behavior)</p> <p>1: The core does U1/U2/U3 exit in PHY power state P1/P2/P3 respectively</p> <p>This bit is added for SS PHY workaround where SS PHY injects a glitch on pipe3_RxEleIdle while receiving Ux exit LFPS, and pipe3_PowerDown change is in progress.</p> <p>Note: This bit is used by third-party SS PHY, else it should be set to '0'.</p>                                                                           |
| 26             | R/W        | 0x0         | <p>ping_enhancement_en</p> <p>Ping Enhancement Enable</p> <p>When set, the Downstream port U1 ping receive timeout becomes 500 ms instead of 300 ms.</p> <p>Minimum Ping.LFPS receive duration is 8 ns (one mac3_clk). This field is valid for Downstream port only.</p> <p>Note: This bit is used by third-party SS PHY, else it should be set to '0'.</p>                                                                                       |
| 25             | R/W        | 0x0         | <p>u1u2exitfail_to_recov</p> <p>U1U2exitfail to Recovery</p> <p>When set, and U1/U2 LFPS handshake fails, the LTSSM transitions from U1/U2 to Recovery instead of SS Inactive. If Recovery fails, then the LTSSM can enter SS.Inactive. This is an enhancement only. It prevents interoperability issue if the remote link does not do proper handshake.</p>                                                                                      |
| 24             | R/W        | 0x1         | <p>request_p1p2p3</p> <p>Always Request P1/P2/P3 for U1/U2/U3</p> <p>When set, the core always requests PHY power change from P0 to P1/P2/P3 during U0 to U1/U2/U3 transition.</p> <p>If this bit is 0, and immediate Ux exit (remotely initiated, or locally initiated) happens, the core does not request P1/P2/P3 power state change.</p> <p>Note: For third-party SS PHY, check with your PHY vendor, else this bit should be set to '1'.</p> |
| 23             | R/W        | 0x0         | <p>StartRxdetU3RxDet</p> <p>Start Receiver Detection in U3/Rx.Detect</p> <p>If USB3_GUSB3PIPECTL_INIT[22] is set, and the link is in either U3 or Rx.Detect state, the core starts receiver detection on the rising edge of this bit. This</p>                                                                                                                                                                                                    |

| Offset: 0xC2C0 |            |             | Register Name: GUSB3PIPECTLn                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                |            |             | can only be used for Downstream ports. This bit must be set to "0" for Upstream ports. This feature must not be enabled for normal operation.                                                                                                                                                                                                                                                                                                                                                                                                  |
| 22             | R/W        | 0x0         | <p>DisRxDetU3RxDet<br/>Disable Receiver Detection in U3/Rx.Det<br/>When set, the core does not handle receiver detection in either U3 or Rx.Detect states.</p> <p>USB3_GUSB3PIPECTL_INIT[23] should be used to start receiver detection manually. This bit can only be used for Downstream port. This bit must be set to "0" for Upstream ports. This feature must not be enabled for normal operation.</p>                                                                                                                                    |
| 21:19          | R/W        | 0x0         | <p>Delay P1P2P3<br/>Delay P0 to P1/P2/P3 request when entering U1/U2/U3 until (DWC_USB3_GUSB3PIPECTL_INIT[21:19]*8) 8B10B error occurs, or Pipe3_RxValid drops to 0.<br/>DWC_USB3_GUSB3PIPECTL_INIT[18] must be 1 to enable this functionality.</p>                                                                                                                                                                                                                                                                                            |
| 18             | R/W        | 0x0         | <p>DELAYP1TRANS<br/>Delay PHY power change from P0 to P1/P2/P3 when link state changing from U0 to U1/U2/U3 respectively</p> <ul style="list-style-type: none"> <li>• 1'b1: When entering U1/U2/U3, delay the transition to P1/P2/P3 until the pipe3 signals, Pipe3_RxElecIlde is 1 and pipe3_RxValid is 0</li> <li>• 1'b0: When entering U1/U2/U3, transition to P1/P2/P3 without checking for Pipe3_RxElecIlde and pipe3_RxValid.</li> </ul> <p>Note: This bit should be set to '1' for self PHY. It is also used by third-party SS PHY.</p> |
| 17             | R/W        | 0x1         | <p>Suspend USB3.1 SS PHY<br/>When set, and if Suspend conditions are valid, the USB 3.1 PHY enters Suspend mode.</p> <p>For DRD/OTG configurations, it is recommended that this bit is set to '0' during coreConsultant configuration. If it is set to '1', then the application should clear this bit after power-on reset.</p> <p>Application needs to set it to '1' after the core</p>                                                                                                                                                      |

| Offset: 0xC2C0 |            |             | Register Name: GUSB3PIPECTLn                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                |            |             | initialization is completed.<br>For all other configurations, this bit can be set to '1' during core configuration.                                                                                                                                                                                                                                                                                                                       |
| 16:15          | R          | 0x0         | DatWidth<br>PIPE Data Width<br><ul style="list-style-type: none"> <li>• 2'b00: 32 bits</li> <li>• 2'b01: 16 bits</li> <li>• 2'b10: 8 bits</li> </ul> One clock after reset, these bits receive the value seen on the "pipe3_DataBusWidth". The simulation testbench uses the coreConsultant parameter to configure the VIP. These bits in the coreConsultant parameter should match your PHY data width and the "pipe_DataBusWidth" port. |
| 14             | R/W        | 0x0         | AbortRxDetInU2<br>Abort Rx Detect in U2<br>When set, and the link state is U2, then the core will abort receiver detection if it receives U2 exit LFPS from the remote link partner. This bit is for Downstream port only.<br><b>Note: This bit is used by third-party SS PHY. It should be set to '0' for self PHY.</b>                                                                                                                  |
| 13             | R/W        | 0x0         | SkipRxDet<br>Skip Rx Detect<br>When set, the core skips Rx Detection if pipe3_RxEleIdle is low. Skip is defined as waiting for the appropriate timeout, then repeating the operation.                                                                                                                                                                                                                                                     |
| 12             | R/W        | 0x0         | LFPS_P0Align<br>LFPS P0 Align<br>When this bit is set, LFPS during U1/U2/U3 exit is extended until data is ready at the PIPE to ensure the 20-ns gap between LFPS and SS/SSP.                                                                                                                                                                                                                                                             |
| 11             | R/W        | 0x0         | P3P2TranOK<br>P3 P2 Transitions OK<br>When set, the core transitions directly from Phy power state P2 to P3 or from state P3 to P2.<br>When not set, P0 is always entered as an intermediate state during transitions between P2 and P3, as defined in the PIPE3 specification.<br>According to PIPE3 Specification, any direct                                                                                                           |

| Offset: 0xC2C0 |            |             | Register Name: GUSB3PIPECTLn                                                                                                                                                                                                                                  |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                   |
|                |            |             | <p>transition between P3 and P2 is illegal. This bit is used only for some non-Synopsys PHYs that cannot do LFPS in P3.</p> <p>Note: This bit is used by third-party SS PHY. It should be set to '0' for self PHY.</p>                                        |
| 10             | R/W        | 0x0         | <p>P3ExSigP2<br/>P3 Exit Signal in P2 (P3ExSigP2)</p> <p>When this bit is set, the controller always changes the PHY power state to P2, before attempting a U3 exit handshake.</p>                                                                            |
| 9              | R/W        | 0x0         | <p>LFPSFilt<br/>LFPS Filter</p> <p>When set, filter LFPS reception with pipe3_RxValid in PHY power state P0, that is, ignore LFPS reception from the PHY unless both pipe3_Rxidle and pipe3_RxValid are deasserted.</p>                                       |
| 8              | R/W        | 0x0         | <p>RX_DETECT to Polling.LFPS Control</p> <p>1'b0 (Default): Enables a 400μs delay to start Polling LFPS after RX_DETECT. This allows VCM offset to settle to a proper level.</p> <p>1'b1: Disables the 400μs delay to start Polling LFPS after RX_DETECT.</p> |
| 7              | /          | /           | /                                                                                                                                                                                                                                                             |
| 6              | R/W        | 0x0         | <p>TxSwing<br/>Tx Swing</p> <p>Refer to the PIPE specification.</p>                                                                                                                                                                                           |
| 5:3            | R/W        | 0x0         | <p>TxMargin<br/>Tx Margin[2:0]</p>                                                                                                                                                                                                                            |
| 2:1            | R/W        | 0x1         | <p>TxDemphasis<br/>Tx Demphasis</p> <p>The value driven to the PHY is controlled by the LTSSM during USB3 Compliance mode.</p>                                                                                                                                |
| 0              | R/W        | 0x0         | <p>ElasticBufferMode<br/>Elastic Buffer Mode</p>                                                                                                                                                                                                              |

#### 8.11.6.31 0xC300+0x04\*n Global Transmit FIFO Size Register n (Default Value: 0x0000\_0043)

| Offset: 0xC300+0x04*n<br>(n=FIFO_number) |            |             | Register Name: GTXFIFOSIZ0 |
|------------------------------------------|------------|-------------|----------------------------|
| Bit                                      | Read/Write | Default/Hex | Description                |

| Offset: 0xC300+0x04*n<br>(n=FIFO_number) |            |             | Register Name: GTXFIFOSIZ0                                                                                                                                                         |
|------------------------------------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                      | Read/Write | Default/Hex | Description                                                                                                                                                                        |
| 31:16                                    | R/W        | 0x0         | TxFStAddr_n<br>Transmit FIFO RAM Start Address<br>This field contains the memory start address for TxFIFO.                                                                         |
| 15                                       | /          | /           | /                                                                                                                                                                                  |
| 14:0                                     | R/W        | 0x43        | TxFDep_n<br>TxFIFO Depth<br>This value is in terms of depth*Tx RAM Data width. <ul style="list-style-type: none"><li>• Minimum value: 32</li><li>• Maximum value: 32,767</li></ul> |

#### 8.11.6.32 0xC380+0x04\*n Global Receive FIFO Size Register n (Default Value: 0x0000\_0413)

| Offset: 0xC380+0x04*n<br>(n=FIFO_number) |            |             | Register Name: GRXFIFOSIZ0                                                                                                                                                         |
|------------------------------------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                      | Read/Write | Default/Hex | Description                                                                                                                                                                        |
| 31:16                                    | R/W        | 0x0         | RxFStAddr_n<br>RxFIFO RAM Start Address<br>This field contains the memory start address for RxFIFO.                                                                                |
| 15                                       | /          | /           | /                                                                                                                                                                                  |
| 14:0                                     | R/W        | 0x413       | RxFDep_n<br>RxFIFO Depth<br>This value is in terms of depth*Tx RAM Data width. <ul style="list-style-type: none"><li>• Minimum value: 32</li><li>• Maximum value: 16,384</li></ul> |

#### 8.11.6.33 0xC400+0x10\*n (0<= n <= EventBuff\_number) Global Event Buffer Address Lower Register n (Default Value:0x0000\_0000)

| Offset: 0xC400+0x10*n (0<= n <= EventBuff_number) |            |             | Register Name: GEVNTADLRn                                                                                                                                   |
|---------------------------------------------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                               | Read/Write | Default/Hex | Description                                                                                                                                                 |
| 31:0                                              | R/W        | 0x0         | EvntAdrLo<br>Holds the lower 32 bits of start address of the external memory for the Event Buffer. During operation, hardware does not update this address. |

**8.11.6.34 0xC404+0x10\*n (0<= n <= EventBuff\_number) Global Event Buffer Address Higher Register n  
(Default Value:0x0000\_0000)**

| Offset: 0xC404+0x10*n (0<= n <= EventBuff_number) |            |             | Register Name: GEVNTADHRn                                                                                                                                    |
|---------------------------------------------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                               | Read/Write | Default/Hex | Description                                                                                                                                                  |
| 31:0                                              | R/W        | 0x0         | EvntAdrHi<br>Holds the higher 32 bits of start address of the external memory for the Event Buffer. During operation, hardware does not update this address. |

**8.11.6.35 0xC408+0x10\*n (0<= n <= EventBuff\_number) Global Event Buffer Size Register n (Default Value:0x0000\_0000)**

| Offset: 0xC408+0x10*n (0<= n <= EventBuff_number) |            |             | Register Name: GEVNTSIZn                                                                                                                                                     |
|---------------------------------------------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                               | Read/Write | Default/Hex | Description                                                                                                                                                                  |
| 31                                                | R/W        | 0x0         | EvntIntMask<br>Event Interrupt Mask<br>When set to '1', this prevents the interrupt from being generated. However, even when the mask is set, the events are queued.         |
| 30:16                                             | /          | /           | /                                                                                                                                                                            |
| 15:0                                              | R/W        | 0x0         | EVNTSiz<br>Event Buffer Size in bytes<br>Holds the size of the Event Buffer in bytes; must be a multiple of four. This is programmed by software once during initialization. |

**8.11.6.36 0xC40C+0x10\*n (0<= n <= EventBuff\_number) Global Event Buffer Count Register n (Default Value:0x0000\_0000)**

| Offset: 0xC40C+0x10*n (0<= n <= EventBuff_number) |            |             | Register Name: GEVNTCOUNTn                                                                                                                                                                                                                                                                                   |
|---------------------------------------------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                               | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                  |
| 31                                                | R/W        | 0x0         | EVNT_HANDLER_BUSY<br>Event Handler Busy<br>Device software event handler busy indication. The controller sets this bit when the interrupt line is asserted due to pending events. Software clears this bit (with 1'b1) when it has finished processing the events (along with updating the EVNTCOUNT in this |

| Offset: 0xC40C+0x10*n (0<= n <= EventBuff_number) |            |             | Register Name: GEVNTCOUNTn                                                                                                                                                                                                       |
|---------------------------------------------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                                               | Read/Write | Default/Hex | Description                                                                                                                                                                                                                      |
|                                                   |            |             | register). The controller does not raise the interrupt line for a new event unless this bit is cleared.<br>Note: When Interrupt moderation is disabled (that is, DEVICE_IMODI = 0), this bit is ignored.                         |
| 30:16                                             | /          | /           | /                                                                                                                                                                                                                                |
| 15:0                                              | R/W        | 0x0         | EVNTCount<br>Event Count<br>When read, returns the number of valid events in the Event Buffer (in bytes). When written, hardware decrements the count by the value written. The interrupt line remains high when count is not 0. |

#### 8.11.6.37 0xC610 Global Device TX FIFO DMA Priority Register (Default Value:0x0000\_0000)

| Offset: 0xC610 |            |             | Register Name: GTXFIFOPRIDEV                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 31:5           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 4:0            | R/W        | 0x0         | gtxfifopriority<br>Device TXFIFO priority<br>This register specifies the relative DMA priority level among the Device TXFIFOs (one per IN endpoint). Each register bit[n] controls the priority (1: high, 0: low) of each TXFIFO[n]. When multiple TXFIFOs compete for DMA service at a given time (that is, multiple TXQs contain TX DMA requests and their corresponding TXFIFOs have space available), the TX DMA arbiter grants access on a packet-basis in the following manner:<br><ol style="list-style-type: none"><li>1. High-priority TXFIFOs are granted access using round-robin arbitration</li><li>2. Low-priority TXFIFOs are granted access using round-robin arbitration only after the high-priority TXFIFOs have no further processing to do (that is, either the TXQs are empty or the corresponding TXFIFOs are full).</li></ol> <p>For scatter-gather packets, the arbiter grants successive DMA requests to the same FIFO until the entire packet is completed.</p> <p>When configuring periodic IN endpoints, software must set register bit[n]=1, where n is the TXFIFO</p> |

| Offset: 0xC610 |            |             | Register Name: GTXFIFOPRIDEV                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                |            |             | <p>assignment. This ensures that the DMA for isochronous or interrupt IN endpoints are prioritized over bulk or control IN endpoints.</p> <p>This register is present only when the controller is configured to operate in the device mode (includes DRD). The register size corresponds to the number of Device IN endpoints.</p> <p>Note</p> <p>Since the device mode uses only one RXFIFO, there is no Device RXFIFO DMA Priority Register.</p> |

#### 8.11.6.38 0xC618 Global Host TX FIFO DMA Priority Register (Default Value:0x0000\_0000)

| Offset: 0xC618 |            |             | Register Name: GTXFIFOPRIHST                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 31:6           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 5:0            | R/W        | 0x0         | <p>gtxfifoprihst<br/>Host TXFIFO priority</p> <p>This register specifies the relative DMA priority level among the Host TXFIFOs (one per USB bus instance) within the associated speed group (SS or HS/FSLS). Each register bit[n] controls the priority (1: high, 0: low) of TXFIFO[n] within a speed group. When multiple TXFIFOs compete for DMA service at a given time (i.e., multiple TXQs contain TX DMA requests and their corresponding TXFIFOs have space available), the TX DMA arbiter grants access on a packet-basis in the following manner:</p> <ol style="list-style-type: none"> <li>1. Among the FIFOs in the same speed group (SS or HS/FSLS):             <ol style="list-style-type: none"> <li>a. High-priority TXFIFOs are granted access using round-robin arbitration</li> <li>b. Low-priority TXFIFOs are granted access using round-robin arbitration only after the high-priority TXFIFOs have no further processing to do (that is, either the TXQs are empty or the corresponding TXFIFOs are full).</li> </ol> </li> <li>2. The TX DMA arbiter prioritizes the SS speed group or HS/FSLS speed group according to the ratio programmed in the GDMAHLRATIO register.</li> </ol> <p>For scatter-gather packets, the arbiter grants</p> |

| Offset: 0xC618 |            |             | Register Name: GTXFIFOPRIHST                                                                                                                                                                                                                                                                                                                                                             |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                              |
|                |            |             | <p>successive DMA requests to the same FIFO until the entire packet is completed.</p> <p>This register is present only when the controller is configured to operate in the host mode (includes DRD). The register size corresponds to the number of configured USB bus instances; for example, in the default configuration, there are 3 USB bus instances (1 SS, 1 HS, and 1 FSLS).</p> |

#### 8.11.6.39 0xC61C Global Host RX FIFO DMA Priority Register (Default Value:0x0000\_0000)

| Offset: 0xC61C |            |             | Register Name: GRXFIFOPRIHST                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 31:5           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 5:0            | R/W        | 0x0         | <p>grxfifoprihst<br/>Host RXFIFO priority</p> <p>This register specifies the relative DMA priority level among the Host RXFIFOs (one per USB bus instance) within the associated speed group (SS or HS/FSLS). Each register bit[n] controls the priority (1: high, 0: low) of RXFIFO[n] within a speed group. When multiple RXFIFOs compete for DMA service at a given time (i.e., multiple RXQs contain RX DMA requests and their corresponding RXFIFOs have data available), the RX DMA arbiter grants access on a packet-basis in the following manner:</p> <ol style="list-style-type: none"> <li>1. Among the FIFOs in the same speed group (SS or HS/FSLS): <ul style="list-style-type: none"> <li>a. High-priority RXFIFOs are granted access using round-robin arbitration</li> <li>b. Low-priority RXFIFOs are granted access using round-robin arbitration only after high-priority RXFIFOs have no further processing to do (that is, either the RXQs are empty or the corresponding RXFIFOs do not have the required data).</li> </ul> </li> <li>2. The RX DMA arbiter prioritizes the SS speed group or HS/FSLS speed group according to the ratio programmed in the GDMAHLRATIO register.</li> </ol> <p>For scatter-gather packets, the arbiter grants successive DMA requests to the same FIFO until the entire packet is completed.</p> |

| Offset: 0xC61C |            |             | Register Name: GRXFIFOPRIHST                                                                                                                                                                                                                                                                |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                 |
|                |            |             | This register is present only when the controller is configured to operate in the host mode (includes DRD). The register size corresponds to the number of configured USB bus instances; for example, in the default configuration, there are 3 USB bus instances (1 SS, 1 HS, and 1 FSLS). |

#### 8.11.6.40 0xC624 Global Host FIFO DMA High-Low Priority Ratio Register (Default Value:0x0A0A\_0101)

| Offset: 0xC624 |            |             | Register Name: GDMAHLRATIO                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 31:29          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 28:24          | R/W        | 0xa         | <p>hstrxfifo_mac<br/>RX MAC ESS Priority Count<br/>Specifies the Global Host FIFO MAC access Ratio Register's (GDMAHLRATIO) RX SS:HSFSLS Ratio power-on initialization value (bit[28:24]).</p> <p>This register specifies MAC write access count relation between ESS FIFOs vs HS+FSLS FIFOs. Specifically, FIFO access arbiter prioritizes the HS+FSLS FIFOs for one clock after the specified number of write access to the SS FIFOs.</p>    |
| 23:21          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 20:16          | R/W        | 0xa         | <p>hsttxfifo_mac<br/>TX MAC ESS Priority Count<br/>Specifies the Global Host FIFO MAC access Ratio Register's (GDMAHLRATIO) TX SS:HSFSLS Ratio power-on initialization value (bit[20:16]).</p> <p>This register specifies MAC read access count relation between ESS FIFOs vs HS+FSLS FIFOs. Specifically, FIFO read access arbiter prioritizes the HS+FSLS FIFOs for one clock after the specified number of read access to the SS FIFOs.</p> |
| 15:13          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 12:8           | R/W        | 0x1         | <p>hstrxfifo_dma<br/>RX DMA ESS Priority Count<br/>Specifies the Global Host FIFO DMA access Ratio Register's (GDMAHLRATIO) RX SS:HSFSLS Ratio power-on initialization value (bit[12:8]).</p> <p>This register specifies the relative priority of the SS FIFOs vs. the HS+FSLS FIFOs. Specifically, the DMA</p>                                                                                                                                |

| Offset: 0xC624 |            |             | Register Name: GDMAHLRATIO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                |            |             | <p>arbiter prioritizes the HS/FSLS round-robin arbiter group for one packet after the specified number of packet grants to the ESS round-robin arbiter group. When a standard driver is used, such as the xHCI driver from Microsoft, this register must be initialized to meet system requirements before synthesizing the controller.</p> <p>If you are developing your own xHCI host driver, then this register can be configured by your driver. It is recommended to keep this value as 1 so that HS/FSLS gets same priority as ESS. The HS/FSLS bandwidth requirement is negligible compared to ESS, so keeping this value as 1 ensures USB 2.0 operation is not affected by high bandwidth ESS.</p>                                                                                                                                                                                                                                                                                                     |
| 7:5            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 4:0            | R/W        | 0x1         | <p>hsttxfifo_dma<br/>TX DMA ESS Priority Count<br/>Specifies the Global Host FIFO DMA access Ratio Register's (GDMAHLRATIO) TX SS:HSFSLS Ratio power-on initialization value (bit[4:0]).</p> <p>This register specifies the access weight of the SS FIFOs vs. the HS+FSLS FIFOs. Specifically, the DMA arbiter prioritizes the HS/FSLS round-robin arbiter group for one packet after the specified number of packet grants to the ESS round-robin arbiter group. When a standard driver is used, such as the xHCI driver from Microsoft, this register must be initialized to meet system requirements before synthesizing the controller.</p> <p>If you are developing your own xHCI host driver, then this register can be configured by your driver. It is recommended to keep this value as 1 so that HS/FSLS gets same priority as ESS. The HS/FSLS bandwidth requirement is negligible compared to ESS, so keeping this value as 1 ensures USB 2.0 operation is not affected by high bandwidth ESS.</p> |

## 8.11.7 Device Register Description

### 8.11.7.1 0xC700 Device Configuration Register (Default Value:0x0008\_0805)

| Offset: 0xC700 |            |             | Register Name: DCFG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 31:24          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 23             | R/W        | 0x0         | <p>ISPP<br/>Ignore Stream Packet Pending<br/>This bit only effect stream-capable bulk endpoints.<br/>When this bit is set to '0' and the controller receives a Data Packet with the Packet Pending (PP) bit set to '0' for OUT endpoints, or it receives an ACK with the NumP field set to '0' and PP set to '0' for IN endpoints, the core attempts to search for another stream (CStream) to initiate to the host.<br/>However, there are two situations where this behavior is not optimal:<br/>When the host is setting PP='0' even though it has not finished the stream, or<br/>When the endpoint on the device is configured with one transfer resource and therefore does not have any other streams to initiate to the host.<br/>When this bit is set to '1', the core ignores the Packet Pending bit for the purposes of stream selection and does not search for another stream when it receives DP(PP='0') or ACK(NumP='0', PP='0'). This can enhance the performance when the device system bus bandwidth is low or the host responds to the core's ERDY transmission very quickly.</p> |
| 22             | R/W        | 0x0         | <p>LPMCAP<br/>LPM Capable<br/>The application uses this bit to control the USB Device LPM capabilities. If the core operates as a non-LPM-capable device, it cannot respond to LPM transactions.<br/>0: LPM capability is not enabled.<br/>1: LPM capability is enabled.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 21:17          | R/W        | 0x4         | <p>NUMP<br/>Number of Receive Buffer<br/>This bit indicates the number of receive buffers to be reported in the ACK TP.<br/>The usb3 controller uses this field if</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

| Offset: 0xC700 |            |             | Register Name: DCFG                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                |            |             | GRXTHRCFG.USBRxPktCntSel is set to '0'. The application can program this value based on RxFIFO size, buffer sizes programmed in descriptors, and system latency.<br>For an OUT endpoint, this field controls the number of receive buffers reported in the NumP field of the ACK TP transmitted by the controller.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 16:12          | R/W        | 0x0         | INTRNUM<br>Interrupt Number<br>Indicates interrupt/EventQ number on which non-endpoint-specific device-related interrupts are generated.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 11:10          | /          | 0x2         | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 9:3            | R/W        | 0x0         | DEVADDR<br>Device Address<br>The application must perform the following:<br>Program this field after every SetAddress control command.<br>Reset this field to zero after USB reset.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 2:0            | R/W        | 0x5         | DEVSPD<br>Device Speed<br>Indicates the speed at which the application requires the controller to connect, or the maximum speed the application can support.<br>However, the actual bus speed is determined only after the chirp sequence is completed, and is based on the speed of the USB host to which the controller is connected.<br>3'b101: Enhanced SuperSpeed (USB 3.1 PHY clock is 156.25 MHz or 312.5 MHz operating at 10Gbps)<br>3'b100: SuperSpeed (USB 3.1 PHY clock is 125 MHz or 250 MHz operating at 5Gbps)<br>3'b000: High-speed (USB 2.0 PHY clock is 30 MHz or 60 MHz)<br>3'b001: Full-speed (USB 2.0 PHY clock is 30 MHz or 60 MHz)<br>Values:<br>0x5 (EnhancedSuperSpeed): Enhanced SuperSpeed (USB 3.1 PHY clock is 156.25 MHz or 312.5 MHz operating at 10Gbps)<br>0x4 (SuperSpeed): SuperSpeed (USB 3.1 PHY clock is |

| Offset: 0xC700 |            |             | Register Name: DCFG                                                                                                                                                                  |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                          |
|                |            |             | 125 MHz or 250 MHz operating at 5Gbps)<br>0x0 (HighSpeed): High-speed (USB 2.0 PHY clock is 30 MHz or 60 MHz)<br>0x1 (FullSpeed): Full-speed (USB 2.0 PHY clock is 30 MHz or 60 MHz) |

#### 8.11.7.2 0xC704 Device Control Register (Default Value:0x0000\_0000)

| Offset: 0xC704 |            |             | Register Name: DCTL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 31             | R/W        | 0x0         | RS<br>Run/Stop<br>Software writes 1 to this bit to start the device controller operation.<br>To stop device controller operation, software must remove any active transfers and write 0 to this bit.<br>When the controller is stopped, it sets the STS.DevCtrlHlt bit when the core is idle and the lower layer finishes the disconnect process.<br>The Run/Stop bit must be used in following cases as specified:<br>After power-on reset and CSR initialization, software must write 1 to this bit to start the device controller.<br>The controller will not signal connect to the host until this bit is set.<br>Software uses this bit to control the device controller to perform a soft disconnect. When software writes 0 to this bit, the host does not see that the device is connected. The device controller stays in the disconnected state until software writes 1 to this bit.<br>If software is attempting a connect after the soft disconnect, it should set DCTL[8:5] to 5 before reasserting the Run/Stop bit.<br>When the USB or Link is in a lower power state and the Two Power Rails configuration is selected, software writes 0 to this bit to indicate that it is going to turn off the Core Power Rail. After the software turns on the Core Power Rail again and re-initializes the device controller, it must set this bit to start the device controller. |

| Offset: 0xC704 |            |             | Register Name: DCTL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 30             | R/W        | 0x0         | <p><b>CSFTRST</b><br/> <b>Core Soft Reset</b><br/>         Resets the all clock domains as follows:<br/>         This bit clears the interrupts and all the CSRs except<br/>         GSTS, USB31_IP_NAME, GPIO, GUID,<br/>         GUSB2PHYCFGn registers, GUSB3PIPECTLn<br/>         registers, DCFG, DCTL, DEVTEN, and DSTS registers.<br/>         All module state machines (except the SoC Bus Slave<br/>         Unit) are reset to the IDLE state, and all the TxFIFOs<br/>         and the Rx FIFO are flushed.</p> <p>Any transactions on the SoC bus Master are<br/>         terminated as soon as possible, after gracefully<br/>         completing the last data phase of a SoC bus transfer.<br/>         Any transactions on the USB are terminated<br/>         immediately.</p> <p>The application can write this bit at any time to reset<br/>         the core. This is a self-clearing bit; the core clears<br/>         this bit after all necessary logic is reset in the core<br/>         and all the PHY clocks are active/running after PHY<br/>         reset, which may take several milliseconds<br/>         depending on the PHY's clock latency. Software can<br/>         have a poll rate of 1 ms or more to check if this bit<br/>         has been cleared or not. Typically, software reset is<br/>         used during software development and also when<br/>         you dynamically change the PHY selection bits in the<br/>         USB configuration registers listed above. When you<br/>         change the PHY, the corresponding clock for the PHY<br/>         is selected and used in the PHY domain. Once a new<br/>         clock is selected, the PHY domain must be reset for<br/>         proper operation.</p> |
| 29             | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 28:24          | R/W        | 0x0         | <p><b>HIRDTH</b><br/> <b>HIRD Threshold</b><br/>         The core asserts output signals<br/>         UTMI_L1_SUSPEND_n and UTMI_SLEEP_n on the<br/>         basis of this signal:</p> <p>The core asserts UTMI_L1_SUSPEND_n to put the<br/>         PHY into Deep Low-Power mode in L1 when both of<br/>         the following are true:</p> <p>HIRD value is greater than or equal to the value in<br/>         DCTL.HIRDTH[3:0]</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

| Offset: 0xC704 |            |             | Register Name: DCTL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                |            |             | <p>DCTL.HIRDTH[4] is set to '1'</p> <p>The core asserts UTMI_SLEEP_n on L1 when one of the following is true:</p> <p>If the HIRD value is less than HIRDTH[3:0] or HIRDTH[4] is set to '0'.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 23:20          | R/W        | 0xf         | <p>LPM_NYET_thres</p> <p>Bits [23:20]: LPM NYET Response Threshold (LPM_NYET_thres)</p> <p>Handshake response to LPM token specified by device application. Response depends on DCFG.LPMCap.</p> <p>DCFG.LPMCap is 1'b0 - The controller always responds with Timeout (that is, no response).</p> <p>DCFG.LPMCap is 1'b1 - The controller responds with an ACK on successful LPM transaction, which requires that all of the following are satisfied:</p> <p>There are no PID or CRC5 errors in both the EXT token and the LPM token (if not true, inactivity results in a timeout ERROR).</p> <p>No data is pending in the TxFIFO and the RxFIFO is empty.</p> <p>The BESL value in the LPM token is less than or equal to LPM_NYET_thres[3:0]</p> |
| 19             | R/W        | 0x0         | <p>KeepConnect</p> <p>When '1', this bit enables the save and restore programming model by preventing the core from disconnecting from the host when DCTL.RunStop is set to '0'. It also enables the Hibernation Request Event to be generated when the link goes to U3 or L2.</p> <p>The device core disconnects from the host when DCTL.RunStop is set to '0'. This bit indicates whether to preserve this behavior ('0'), or if the core should not disconnect when RunStop is set to 0 ('1').</p> <p>This bit also prevents the LTSSM from automatically going to U0/L0 when the host requests resume from U3/L2.</p>                                                                                                                           |
| 18             | R/W        | 0x0         | <p>L1HibernationEn</p> <p>When this bit is set along with KeepConnect, the device core generates a Hibernation Request Event if L1 is enabled and the HIRD value in the LPM token is</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

| Offset: 0xC704 |            |             | Register Name: DCTL                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                              |
|                |            |             | larger than the threshold programmed in DCTL.HIRD_Thres. The core will not exit the LPM L1 state until software writes Recovery into the DCTL.ULStChngReq field. This prevents corner cases where the device is entering hibernation at the same time the host is attempting to exit L1.                                                 |
| 17             | W          | 0x0         | CRS<br>Controller Restore State<br>This command is similar to the USBCMD.CRS bit in host mode and initiates the restore process. When software sets this bit to '1', the controller immediately sets DSTS.RSS to '1'. When the controller has finished the restore process, it sets DSTS.RSS to '0'.                                     |
| 16             | W          | 0x0         | CSS<br>Controller Save State<br>This command is similar to the USBCMD.CSS bit in host mode and initiates the save process. When software sets this bit to '1', the controller immediately sets DSTS.SSS to '1'. When the controller has finished the save process, it sets DSTS.SSS to '0'.                                              |
| 15:13          | /          | /           | /                                                                                                                                                                                                                                                                                                                                        |
| 12             | R/W        | 0x0         | INITU2EN<br>Initiate U2 Enable<br>0x0: May not initiate U2<br>0x1: May initiate U2<br>On USB reset, hardware clears this bit to "0".<br>Software sets this bit after receiving SetFeature(U2_ENABLE), and clears this bit when ClearFeature(U2_ENABLE) is received. If DCTL[11] (AcceptU2Ena) is 0, the link immediately exits U2 state. |
| 11             | R/W        | 0x0         | ACCEPTU2EN<br>Accept U2 Enable<br>0x0: Reject U2 except when Force_LinkPM_Accept bit is set<br>0x1: Core accepts transition to U2 state if nothing is pending on the application side.<br>On USB reset, hardware clears this bit to "0".<br>Software sets this bit after receiving a                                                     |

| Offset: 0xC704 |            |             | Register Name: DCTL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                |            |             | SetConfiguration command.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 10             | R/W        | 0x0         | <p>INITU1EN<br/>Initiate U1 Enable<br/>0x0: May not initiate U1<br/>0x1: May initiate U1<br/>On USB reset, hardware clears this bit to “0”.<br/>Software sets this bit after receiving SetFeature(U1_ENABLE), and clears this bit when ClearFeature(U1_ENABLE) is received.<br/>If DCTL[9] (AcceptU1Ena) is 0, the link immediately exits U1 state.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 9              | R/W        | 0x0         | <p>ACCEPTU1EN<br/>Accept U1 Enable<br/>0x0: Reject U1 except when Force_LinkPM_Accept bit is set<br/>0x1: Core accepts transition to U1 state if nothing is pending on the application side.<br/>On USB reset, hardware clears this bit to “0”.<br/>Software sets this bit after receiving a SetConfiguration command.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 8:5            | R/W        | 0x0         | <p>ULSTCHGREQ<br/>USB/Link State Change Request<br/>Software writes this field to issue a USB/Link state change request. A change in this field indicates a new request to the core. If software wants to issue the same request back-to-back, it must write a 0 to this field between the two requests. The result of the state change request is reflected in the USB/Link State in DSTS. These bits are self-cleared on the MAC Layer exiting suspended state.<br/>If software is updating other fields of the DCTL register and not intending to force any link state change, then it must write a 0 to this field.<br/>SS Compliance mode is normally entered and controlled by the remote link partner. Refer to the USB3 specification. Alternatively, you can force the local link directly into Compliance mode, by resetting the SS link with the RUN/STOP bit set to zero. If you then write “10” to the USB/Link State Change field and “1” to RUN/STOP, the Link will go to Compliance. Once you are in Compliance, you</p> |

| Offset: 0xC704 |                                        |             | Register Name: DCTL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |       |                                        |   |           |   |             |   |           |   |             |   |          |    |            |        |          |       |                                |   |                       |
|----------------|----------------------------------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|----------------------------------------|---|-----------|---|-------------|---|-----------|---|-------------|---|----------|----|------------|--------|----------|-------|--------------------------------|---|-----------------------|
| Bit            | Read/Write                             | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |       |                                        |   |           |   |             |   |           |   |             |   |          |    |            |        |          |       |                                |   |                       |
|                |                                        |             | <p>may alternately write “zero” and “10” to this field to advance the compliance pattern.</p> <p>In SS mode:</p> <table> <tr><td>Value</td><td>Requested Link State Transition/Action</td></tr> <tr><td>0</td><td>No Action</td></tr> <tr><td>4</td><td>SS.Disabled</td></tr> <tr><td>5</td><td>Rx.Detect</td></tr> <tr><td>6</td><td>SS.Inactive</td></tr> <tr><td>8</td><td>Recovery</td></tr> <tr><td>10</td><td>Compliance</td></tr> <tr><td>Others</td><td>Reserved</td></tr> </table> <p>In HS/FS/LS mode:</p> <table> <tr><td>Value</td><td>Requested USB state transition</td></tr> <tr><td>8</td><td>Remote wakeup request</td></tr> </table> <p>Others Reserved</p> <p>The Remote wakeup request should be issued <math>2\mu s</math> after the device goes into suspend state (DSTS[21:18] is 3 ).</p> <p>Note: After coming out of hibernation, software should write 8 (Recovery) into this field to confirm exit from the suspended state</p> | Value | Requested Link State Transition/Action | 0 | No Action | 4 | SS.Disabled | 5 | Rx.Detect | 6 | SS.Inactive | 8 | Recovery | 10 | Compliance | Others | Reserved | Value | Requested USB state transition | 8 | Remote wakeup request |
| Value          | Requested Link State Transition/Action |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |                                        |   |           |   |             |   |           |   |             |   |          |    |            |        |          |       |                                |   |                       |
| 0              | No Action                              |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |                                        |   |           |   |             |   |           |   |             |   |          |    |            |        |          |       |                                |   |                       |
| 4              | SS.Disabled                            |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |                                        |   |           |   |             |   |           |   |             |   |          |    |            |        |          |       |                                |   |                       |
| 5              | Rx.Detect                              |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |                                        |   |           |   |             |   |           |   |             |   |          |    |            |        |          |       |                                |   |                       |
| 6              | SS.Inactive                            |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |                                        |   |           |   |             |   |           |   |             |   |          |    |            |        |          |       |                                |   |                       |
| 8              | Recovery                               |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |                                        |   |           |   |             |   |           |   |             |   |          |    |            |        |          |       |                                |   |                       |
| 10             | Compliance                             |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |                                        |   |           |   |             |   |           |   |             |   |          |    |            |        |          |       |                                |   |                       |
| Others         | Reserved                               |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |                                        |   |           |   |             |   |           |   |             |   |          |    |            |        |          |       |                                |   |                       |
| Value          | Requested USB state transition         |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |                                        |   |           |   |             |   |           |   |             |   |          |    |            |        |          |       |                                |   |                       |
| 8              | Remote wakeup request                  |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |       |                                        |   |           |   |             |   |           |   |             |   |          |    |            |        |          |       |                                |   |                       |
| 4:1            | R/W                                    | 0x0         | <p>TSTCTL</p> <p>Test Control</p> <ul style="list-style-type: none"> <li>• 4'b000: Test mode disabled</li> <li>• 4'b001: Test_J mode</li> <li>• 4'b010: Test_K mode</li> <li>• 4'b011: Test_SE0_NAK mode</li> <li>• 4'b100: Test_Packet mode</li> <li>• 4'b101: Test_Force_Enable</li> <li>• Others: Reserved</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |       |                                        |   |           |   |             |   |           |   |             |   |          |    |            |        |          |       |                                |   |                       |
| 0              | /                                      | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |       |                                        |   |           |   |             |   |           |   |             |   |          |    |            |        |          |       |                                |   |                       |

#### 8.11.7.3 0xC708 Device Event Enable Register (Default Value:0x0000\_0000)

| Offset: 0xC708 |            |             | Register Name: DEVREN                                                                                                |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                          |
| 31:16          | /          | /           | /                                                                                                                    |
| 15             | R/W        | 0x0         | <p>LDMEVTEN</p> <p>LDM Response Event Enable.</p> <p>Enables interrupt when response to LDM request is received.</p> |

| Offset: 0xC708 |            |             | Register Name: DEVTEN                                                                                        |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                  |
| 14             | R/W        | 0x0         | L1WKUPEVTEN<br>L1 Resume Detected Event Enable.                                                              |
| 13             | /          | /           | /                                                                                                            |
| 12             | R/W        | 0x0         | VndrDevTstRcvEn<br>Vendor Device Test LMP Received Event Enable                                              |
| 11:10          | /          | /           | /                                                                                                            |
| 9              | R/W        | 0x0         | ErrticErrEn<br>Erratic Error Event Enable                                                                    |
| 8              | R/W        | 0x0         | L1SUSPEN<br>L1 Suspend Event Enable                                                                          |
| 7              | R/W        | 0x0         | SofEn<br>Start of (micro-)Frame Enable<br>For debug purpose only; normally software must disable this event. |
| 6              | R/W        | 0x0         | U3L2L1SuspEn<br>U3/L2-L1 Suspend Event Enable.                                                               |
| 5              | R/W        | 0x0         | HibernationReqEvtEn<br>This bit enables/disables the generation of the Hibernation Request Event.            |
| 4              | R/W        | 0x0         | WkUpEvtEn<br>Resume/Remote Wakeup Detected Event Enable                                                      |
| 3              | R/W        | 0x0         | ULStChgEn<br>USB/Link State Change Event Enable                                                              |
| 2              | R/W        | 0x0         | ConnectDoneEn<br>Connect Done Enable                                                                         |
| 1              | R/W        | 0x0         | USBRstEn<br>USB Reset Enable                                                                                 |
| 0              | R/W        | 0x0         | DisconnEvtEn<br>Disconnect Detected Event Enable                                                             |

#### 8.11.7.4 0xC70C Device Status Register (Default Value:0x0002\_0004)

| Offset: 0xC70C |            |             | Register Name: DSTS                                                                                                                                                                                 |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                         |
| 31:30          | /          | /           | /                                                                                                                                                                                                   |
| 29             | R          | 0x0         | DCNRD<br>Device Controller Not Ready<br>The bit indicates that the core is in the process of completing the state transitions after exiting from hibernation. To complete the state transitions, it |

| Offset: 0xC70C |            |             | Register Name: DSTS                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                |            |             | takes 256 bus clock cycles from the time DCTL[31].Run/Stop is set. During hibernation, if the UTMI/ULPI PHY is in suspended state, then the 256-bus clock cycle delay starts after the PHY exited suspended state. Software must set DCTL[31].Run/Stop to '1' and wait for this bit to be de-asserted to zero before processing DSTS.USBLnkSt.<br>This bit is valid only when USB3_EN_PWROPT is set to 2 and GCTL[1].GblHibernationEn =1. |
| 28             | R/W1C      | 0x0         | SRE<br>Save/Restore Error<br>This bit is currently not supported.                                                                                                                                                                                                                                                                                                                                                                         |
| 27:26          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 25             | R          | 0x0         | RSS<br>Restore State Status<br>This bit is similar to the USBSTS.RSS in host mode. When the controller has finished the restore process, it will complete the command by setting DSTS.RSS to '0'.                                                                                                                                                                                                                                         |
| 24             | R          | 0x0         | SSS<br>Save State Status<br>This bit is similar to the USBSTS.SSS in host mode. When the controller has finished the save process, it will complete the command by setting DSTS.SSS to '0'.                                                                                                                                                                                                                                               |
| 23             | R          | 0x0         | Coreidle<br>Core Idle<br>The bit indicates that the core finished transferring all RxFIFO data to system memory, writing out all completed descriptors, and all Event Counts are zero.<br><b>Note:</b> While testing for Reset values, mask out the read value. This bit represents the changing state of the core and does not hold a static value.                                                                                      |
| 22             | R          | 0x0         | DevCtrlHlt<br>Device Controller Halted<br>This bit is set to 0 when the Run/Stop bit in the DCTL register is set to 1.<br>The core sets this bit to 1 when, after SW sets Run/Stop to '0', the core is idle and the lower layer                                                                                                                                                                                                           |

| Offset: 0xC70C |            |             | Register Name: DSTS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 21:18          | R          | 0x0         | <p>finishes the disconnect process.<br/>When Halted =1, the core does not generate Device events.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                |            |             | <p>USBLnkSt<br/>USB/Link State</p> <p>In SS mode: (LTSSM State)</p> <ul style="list-style-type: none"> <li>0x0: U0</li> <li>0x1: U1</li> <li>0x2: U2</li> <li>0x3: U3</li> <li>0x4: SS_DIS</li> <li>0x5: RX_DET</li> <li>0x6: SS_INACT</li> <li>0x7: POLL</li> <li>0x8: RECOV</li> <li>0x9: HRESET</li> <li>0xA: CMPLY</li> <li>0xB: LPBK</li> <li>0xF: Resume/Reset</li> </ul> <p>In HS/FS/LS mode:</p> <ul style="list-style-type: none"> <li>0x0: On state</li> <li>0x2: Sleep state</li> <li>0x3: Suspend state</li> <li>0x4: Disconnected state (Default state)</li> <li>0x5: Early Suspend state (valid only when Hibernation is disabled, GCTL [1]. GblHibernationEn =0)</li> <li>0xE: Reset (valid only when Hibernation is disabled, GCTL [1]. GblHibernationEn =1)</li> <li>0xF: Resume (valid only when Hibernation is disabled, GCTL [1]. GblHibernationEn=1)</li> </ul> <p>The Resume/Reset link state indicates that the core received a resume or USB reset request from the host while the link was in hibernation. Software must write '8' (Recovery) to the DCTL.ULStChngReq field to acknowledge the resume/reset request.</p> <p>The Early Suspend link state is an early indication of device suspend in HS/FS. The link state changes to Early Suspend after detecting bus idle for 3ms.</p> |

| Offset: 0xC70C |            |             | Register Name: DSTS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                |            |             | <p>In HS operation, this is an indication that the USB bus (that is, LineState) has been in idle (SE0) for 3ms. However, it does not confirm whether the next process is Suspend or Reset. The device checks the bus again after pull up enable delay and if the line state indicates Suspend (full speed J), then the device waits for additional time (~3ms) to indicate the actual Suspend state.</p> <p>In FS operation, this is an indication that the USB bus (that is, LineState) has been in idle (J) for 3ms. The device waits for additional time (~3ms of Idle) to indicate the actual Suspend state.</p> <p>When Hibernation is enabled, GCTL [1].</p> <p>GblHibernationEn = 1, this field USBLnkSt is valid only when DCTL [31].Run/Stop set to '1' and DSTS[ 29].DCNRD = 0.</p> |
| 17             | R          | 0x1         | RXFIFOEMP<br>RxFIFO Empty                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 16:3           | R          | 0x0000      | <p>SOFFN<br/>Frame/Micro-Frame Number of the Received SOF<br/>When the controller is operating at SuperSpeed/SuperSpeedPlus,<br/>[16:3] indicates the microframe/ITP number<br/>When the core is operating at high-speed,<br/>[16:6] indicates the frame number<br/>[5:3] indicates the microframe number<br/>When the core is operating at full- or low-speed,<br/>[16:14] is not used. Software can ignore these 3 bits<br/>[13:3] indicates the frame number</p>                                                                                                                                                                                                                                                                                                                           |
| 2:0            | R          | 0x4         | <p>ConnectSpd<br/>Connected Speed<br/>Indicates the speed at which the core has come up after speed detection through a chirp sequence.<br/>0x0: High-Speed (PHY clock is running at 30 or 60 MHz)<br/>0x1: Full-Speed (PHY clock is running at 30 or 60 MHz)<br/>0x4: Super-Speed (PHY clock is running at 125 or 250 MHz)<br/>Low-speed is not supported for device using a UTMI+ PHY</p>                                                                                                                                                                                                                                                                                                                                                                                                   |

#### 8.11.7.5 0xC710 Device Generic Command Parameter Register (Default Value:0x0000\_0000)

| Offset: 0xC710 |            |             | Register Name: DGCMMDPAR                                                                                                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                       |
| 31:0           | R/W        | 0x0         | PAR<br>Parameter [31:0]<br>This register indicates the device command parameter. This must be programmed before or along with the device command. |

#### 8.11.7.6 0xC714 Device Generic Command Register (Default Value:0x0000\_0000)

| Offset: 0xC714 |            |             | Register Name: DGCMMD                                                                                                                                                                                                                                                             |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                       |
| 31:16          | /          | /           | /                                                                                                                                                                                                                                                                                 |
| 15:12          | R          | 0x0         | CMDSTS<br>Command Status<br>1: CmdErr: Indicates that the device controller encountered an error while processing the command.<br>0: Indicates command success.                                                                                                                   |
| 11             | /          | /           | /                                                                                                                                                                                                                                                                                 |
| 10             | R/W        | 0x0         | CMDACT<br>Command Active<br>The software sets this bit to '1' to enable the device controller to execute the generic command.<br>The device controller clears this bit to '0' after executing the command.                                                                        |
| 9              | /          | /           | /                                                                                                                                                                                                                                                                                 |
| 8              | R/W        | 0x0         | CMDIOC<br>Command Interrupt on Complete<br>When this bit is set, the device controller issues a Generic Command Completion event after executing the command. Note that this interrupt is mapped to DCFG.IntrNum.                                                                 |
| 7:0            | R/W        | 0x00        | CMDTYP<br>Command Type<br>Specifies the type of command the software driver is requesting the core to perform.<br>02h: Set Periodic Parameters<br>04h: Set Scratchpad Buffer Array Address Lo<br>05h: Set Scratchpad Buffer Array Address Hi<br>07h: Transmit Device Notification |

| Offset: 0xC714 |            |             | Register Name: DGCMD                                                                                                                         |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                  |
|                |            |             | 09h: Selected FIFO Flush<br>0Ah: All FIFO Flush<br>0Ch: Set Endpoint NRDY<br>11h: Restart After Disconnect<br>All other values are reserved. |

#### 8.11.7.7 0xC718 Device Control Register 1 (Default Value:0x0000\_0000)

| Offset: 0xC718 |            |             | Register Name: DCTL1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 31:3           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 2              | R/W        | 0x0         | <p>EN_ENDXFER_ON_RJCT_STRM<br/>Enable bit for new reject stream flow. On receiving a reject stream(FFFF) on USB side, Controller updates the application SW with STREAMEVT_NOTFOUND with streamid as FFFF, On decoding this event application SW needs to apply an ENDXFER command which flushes all FIFO's .<br/>Until an ENDXFER is issued, Any stream packet received(on USB) will not lead to search of available streams in cache and release of ERDY.Controller writes STREAM_NOT_FOUND events until ENDXFER completion.</p> <p>0: Feature disabled. No Reject status is updated to application SW.<br/>1: Feature enabled, Reject staus is updated on receiving a reject stream(on USB).Decoding this event application SW needs to apply an ENDXFER.</p> |
| 1              | R/W        | 0x0         | <p>DIS_CLRSPR_SXFER<br/>Disable bit to clear intrenal SPR bit during start transfer.<br/>If an End Transfer Command is issued during a transfer, there is a possibility that the internal SPR (short packet received/retry received) gets set, but not cleared.<br/>The SPR clearing is now done when the new Start Transfer command is issued.<br/>Using this register bit, you can disable the clearing of the SPR bit during a Start Transfer command.<br/>0: The SPR bit is cleared when a Start Transfer command is issued (default value).</p>                                                                                                                                                                                                             |

| Offset: 0xC718 |            |             | Register Name: DCTL1                                                   |
|----------------|------------|-------------|------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                            |
|                |            |             | 1: The SPR bit is not cleared when a Start Transfer command is issued. |
| 0              | /          | /           | /                                                                      |

#### 8.11.7.8 0xC720 Device Active USB Endpoint Enable Register (Default Value:0x0000\_0000)

| Offset: 0xC720 |            |             | Register Name: DALEPENA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 31:0           | R/W        | 0x00000000  | <p>USBACTEP<br/>USB Active Endpoints</p> <p>This field indicates if a USB endpoint is active in the current configuration and interface. It applies to USB IN endpoints 0–15 and OUT endpoints 0–15, with one bit for each of the 32 possible endpoints. Even numbers are for USB OUT endpoints, and odd numbers are for USB IN endpoints, as follows:</p> <ul style="list-style-type: none"> <li>Bit[0]: USB EP0-OUT</li> <li>Bit[1]: USB EP0-IN</li> <li>Bit[2]: USB EP1-OUT</li> <li>Bit[3]: USB EP1-IN</li> <li>...</li> </ul> <p>The entity programming this register must set bits 0 and 1 because they enable control endpoints that map to physical endpoints (resources) after USBReset.</p> <p>Application software clears these bits for all endpoints (other than EP0- OUT and EP0-IN) after detecting a USB reset. After receiving SetConfiguration and SetInterface request, the application must program endpoint registers accordingly and set these bits.</p> |

#### 8.11.7.9 0xC724 Device LDM Request Control Register (Default Value:0x0000\_0000)

| Offset: 0xC724 |            |             | Register Name:DLDMENA                                                                                                         |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                   |
| 31:16          | R/W        | 0x0         | <p>LDMADJ</p> <p>LDM request interval duration</p> <p>This field indicates Link Delay adjustment in terms of nano-seconds</p> |

| Offset: 0xC724 |            |             | Register Name:DLDMENA                                                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                |
|                |            |             | <p>After receiving Link Delay through LDM events the application must set these bits with average value.</p> <p>After receiving ClearFeature(LDM_ENABLE) the application must program and reset these bits.</p>                                                                                                                                                            |
| 15:8           | R/W        | 0x0         | <p>LDMRDUR</p> <p>LDM request interval duration</p> <p>This field indicates gap between two LDM request in terms of microframes</p> <p>After receiving SetFeature(LDM_ENABLE) the application must set these bits.</p> <p>After receiving ClearFeature(LDM_ENABLE) the application must program and reset these bits.</p>                                                  |
| 7:4            | R/W        | 0x0         | <p>NOLOWPWRDUR</p> <p>No Low Power Duration</p> <p>After starting a transfer on an ESS ISOC endpoint, the application must program these bits.</p> <p>Each count represents the duration in terms of 8 ms. For example, a value of 3 represents 24 ms.</p>                                                                                                                 |
| 3:1            | R/W        | 0x0         | <p>LDMRQS</p> <p>LDM number of requests</p> <p>This field indicates how many LDM requests Controller sends. A value of zero indicates request to send forever</p> <p>After receiving SetFeature(LDM_ENABLE) the application must set these bits.</p> <p>After receiving ClearFeature(LDM_ENABLE) the application must program and reset these bits</p>                     |
| 0              | R/W        | 0x0         | <p>LDMENA</p> <p>LDM enabled</p> <p>This field indicates PTM protocol LDM request is enabled</p> <p>After receiving SetFeature(LDM_ENABLE) the application must set this bit.</p> <p>After receiving ClearFeature(LDM_ENABLE) the application must program and reset this bit.</p> <p>After receiving 4 consecutive timeout response to LDM, Hardware resets this bit.</p> |

**8.11.7.10 0xC800 + 0x10\*n (n=0-9) Device Physical Endpoint-n Command Parameter 2 Register (Default Value:0x0000\_0000)**

| Offset: 0xC800 + 0x10*n (n=0-9) |            |             | Register Name: DEPCMDPAR2_n (n=0-31)                                                                                                        |
|---------------------------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                             | Read/Write | Default/Hex | Description                                                                                                                                 |
| 31:0                            | R/W        | 0x00000000  | PAR2<br>Parameter 2<br>This register indicates the physical endpoint command Parameter 2. It must be programmed before issuing the command. |

**8.11.7.11 0xC804 + 0x10\*n (n=0-9) Device Physical Endpoint-n Command Parameter 1 Register (Default Value:0x0000\_0000)**

| Offset: 0xC804 + 0x10*n (n=0-9) |            |             | Register Name: DEPCMDPAR1_n (n=0-31)                                                                                                        |
|---------------------------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                             | Read/Write | Default/Hex | Description                                                                                                                                 |
| 31:0                            | R/W        | 0x00000000  | PAR1<br>Parameter 1<br>This register indicates the physical endpoint command Parameter 1. It must be programmed before issuing the command. |

**8.11.7.12 0xC808 + 0x10\*n (n=0-9) Device Physical Endpoint-n Command Parameter 0 Register (Default Value:0x0000\_0000)**

| Offset: 0xC808 + 0x10*n (n=0-9) |            |             | Register Name: DEPCMDPAR0_n (n=0-31)                                                                                                                                                                                                                  |
|---------------------------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                             | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                           |
| 31:0                            | R/W        | 0x00000000  | PAR0<br>Parameter 0<br>This register indicates the physical endpoint command Parameter 0. This must be programmed before or along with the command. For commands needing only one 32-bit parameter, it must be programmed before issuing the command. |

**8.11.7.13 0xC80C + 0x10\*n (n=0-9) Device Physical Endpoint-n Command Register (Default Value:0x0000\_0000)**

| Offset: 0xC80C + 0x10*n (n=0-9) | Register Name: DEPCMD_n (n=0-31) |
|---------------------------------|----------------------------------|
|---------------------------------|----------------------------------|

| Bit   | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16 | R/W        | 0x0000      | <p>CMDPAR (W)<br/>           Command Parameters, when this register is written:<br/>           For Start Transfer command:<br/>           [31:16]: Stream ID. The USB Stream ID assigned to this transfer<br/>           For Start Transfer command applied to an isochronous endpoint:<br/>           [31:16]: Start Micro-Frame Number, indicates the (micro-)frame number to which the first TRB applies<br/>           For Update Transfer, End Transfer, and Start New Configuration commands:<br/>           [22:16]: Transfer Resource Index (XferRsclidx). The hardware-assigned transfer resource index for the transfer, which was returned in response to the Start Transfer command. The application software-assigned transfer resource index for a Start New Configuration command.</p> <p>EVTPAR (R)<br/>           Event Parameters, when this register is read:<br/>           For XferNotReady, XferComplete, and Stream events on Bulk Endpoints:<br/>           [31:16]: StreamID. Applies only to bulk endpoints that support streams. This indicates the Stream ID of the transfer for which the event is generated<br/>           For XferInProgress:<br/>           [31:16]: Isochronous Microframe Number (IsocMicroFrameNum): Indicates the microframe number of the beginning of the interval that generated the XferInProgress event (debug purposes only)<br/>           For XferNotReady events on Isochronous Endpoints:<br/>           [31:16]: Isochronous Microframe Number (IsocMicroFrameNum). Indicates the microframe number during which the endpoint was not ready<br/>           EPCmdCmplt events<br/>           For all EPCmdCmplt events<br/>           [27:24]: Command Type. The command type that completed (Valid only in a DEPEVT event. Undefined when read from the DEPCMD.EventParam field).<br/>           For EPCmdCmplt events in response to Get Data Sequence command:<br/>           [20:16]: Current Data Sequence Number (CurDatSeqNum). The endpoint's current data sequence number is returned in this field.<br/>           For EPCmdCmplt event in response to Start Transfer command:<br/>           [22:16]: Transfer Resource Index (XferRsclidx). The internal</p> |

| Offset: 0xC80C + 0x10*n (n=0-9) |            |             | Register Name: DEPCMD_n (n=0-31)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---------------------------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                             | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                                 |            |             | <p>hardware transfer resource index assigned to this transfer. This index must be used in all Update Transfer and End Transfer commands.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 15:12                           | R/W        | 0x0         | <p>CMDSTS<br/>Command Completion Status<br/>Additional information about the completion of this command is available in this field.</p> <p>Within an XferNotReady event:</p> <ul style="list-style-type: none"> <li>• [15]: Indicates the reason why the XferNotReady event is generated: <ul style="list-style-type: none"> <li>- 1'b0: XferNotActive: Host initiated a transfer, but the requested transfer is not present in the hardware</li> <li>- 1'b1: XferActive: Host initiated a transfer, the transfer is present, but no valid TRBs are available</li> </ul> </li> <li>• [14]: Not Used</li> <li>• [13:12]: For control endpoints, indicates what stage was requested when the transfer was not ready: <ul style="list-style-type: none"> <li>- 2'b00: SETUP Request</li> <li>- 2'b01: Control Data Request</li> <li>- 2'b10: Control Status Request</li> </ul> </li> </ul> <p>Within an XferComplete or XferInProgress event:</p> <ul style="list-style-type: none"> <li>• [15]: LST bit of the completed TRB (XferComplete only)</li> <li>• [15]: MissedIsoc: Indicates the interval did not complete successfully (XferInProgress only)</li> <li>• [14]: IOC bit of the TRB that completed</li> <li>• [13]: Indicates the TRB completed with a short packet reception or the last packet of an isochronous interval</li> <li>• [12]: Indicates a Bus Error occurred If the host aborted the data stage or an isochronous time passed condition occurred, the EventStatus bits may all be '0', with the reason for the transfer completion reflected in the TRB Status field.</li> </ul> <p>Within a Stream Event:</p> <ul style="list-style-type: none"> <li>• [15:12]: <ul style="list-style-type: none"> <li>- 4'h2: StreamNotFound: This stream event is issued when the stream-capable endpoint performed a search in its transfer resource cache, but could not find an active and ready stream.</li> <li>- 4'h1: StreamFound: This stream event is issued when the</li> </ul> </li> </ul> |

| Offset: 0xC80C + 0x10*n (n=0-9) |            |             | Register Name: DEPCMD_n (n=0-31)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------------------------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                             | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                                 |            |             | <p>stream-capable endpoint found an active and ready stream in its transfer resource cache, and initiated traffic for that stream to the host. The ID of the selected Stream is in the EventParam field.</p> <p>In response to a Start Transfer command:</p> <ul style="list-style-type: none"> <li>• [15:12]: <ul style="list-style-type: none"> <li>- 4'h2: Indicates expiry of the bus time reflected in the Start Transfer command.</li> <li>- 4'h1: Indicates there is no transfer resource available on the endpoint.</li> </ul> </li> </ul> <p>In response to a Set Transfer Resource (DEPXFERCFG) command:</p> <ul style="list-style-type: none"> <li>• [15:12]: <ul style="list-style-type: none"> <li>- 4'h1: Indicates an error has occurred because software is requesting more transfer resources to be assigned than have been configured in the hardware.</li> </ul> </li> </ul> |
| 11                              | R/W        | 0x0         | <p>ForceRM<br/>ForceRM: Only valid for End Transfer command<br/>ClearPendIN: Software sets this bit to clear any pending IN transaction (on that endpoint) stuck at the lower layers when a Clear Stall command is issued.<br/>Only valid for Clear Stall command<br/>Only applicable for SS and ESS mode of operation</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 10                              | R/W        | 0x0         | <p>CMDACT<br/>Command Active<br/>Software sets this bit to '1' to enable the device endpoint controller to execute the generic command.<br/>The device controller clears this bit to '0' when the CMDSTS field is valid and the endpoint is ready to accept another command.<br/>This does not imply that all the effects of the previously-issued command have taken place.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 9                               | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 8                               | R/W        | 0x0         | <p>CMDIOC<br/>Command Interrupt on Complete<br/>When this bit is set, the device controller issues a generic Endpoint Command Complete event after executing the command. Note that this interrupt is mapped to DEPCFG.IntrNum. When the DEPCFG command is executed, the command interrupt on completion goes to the interrupt pointed by the DEPCFG.IntrNum in the current command.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

| Offset: 0xC80C + 0x10*n (n=0-9) |            |             | Register Name: DEPCMD_n (n=0-31)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------------------------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                             | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 7:4                             | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 3:0                             | R/W        | 0x0         | <p>CMDTYP<br/>Command Type<br/>Specifies the type of command the software driver is requesting the core to perform.</p> <p>0x0: Reserved<br/>0x1: Set Endpoint Configuration, 64-bit Parameter<br/>0x2: Set Endpoint Transfer Resource Configuration, 32-bit Parameter<br/>0x3: Get Endpoint State, No Parameter Needed<br/>0x4: Set Stall, No Parameter Needed<br/>0x5: Clear Stall, No Parameter Needed<br/>0x6: Start Transfer, 64-bit parameter<br/>0x7: Update Transfer, No Parameter Needed<br/>0x8: End Transfer, No Parameter Needed<br/>0x9: Start New Configuration, No Parameter Needed</p> |

#### 8.11.7.14 0xCA00 Device Interrupt Moderation Register (Default Value:0x0000\_0000)

| Offset: 0xCA00 |            |             | Register Name: DEPIMOD                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 31:16          | R/W        | 0x0000      | <p>DEVICE_IMODC<br/>Interrupt Moderation Down Counter<br/>Loaded with the DEVICE_IMODI value, whenever the hardware interrupt(n) line is de-asserted from the asserted state, counts down to 0, and stops.<br/>The interrupt(n) is signaled whenever this counter is 0, EVNT_HANDLER_BUSY is 0, and there are pending events (that is, event count is non-zero).<br/>This counter may be directly written by software at any time to alter the interrupt rate.</p> |
| 15:0           | R/W        | 0x0         | <p>DEVICE_IMODI<br/>Moderation Interval (DEVICE_IMODI)<br/>This field holds the minimum inter-interrupt interval between events. The interval is specified in terms of 250ns increments.<br/>A value of 0 disables the interrupt throttling logic and interrupts are generated immediately if event count becomes non-zero.<br/>In scaledown simulation mode, 4 ram clocks are</p>                                                                                 |

| Offset: 0xCA00 |            |             | Register Name: DEPIMOD |
|----------------|------------|-------------|------------------------|
| Bit            | Read/Write | Default/Hex | Description            |
|                |            |             | used to time 250ns     |

### 8.11.8 Application Register Description

#### 8.11.8.1 0x100000 USB2.0 Interface Status and Control Register (Default Value: 0x0000\_0000)

| Offset: 0x100000 |            |             | Register Name:USB2_ISCR                                                                                                                                                                                        |
|------------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit              | Read/Write | Default/Hex | Description                                                                                                                                                                                                    |
| 31:27            | R          | 0           | BC_ID_Value_Status<br>These fields indicate the Mult ID value.                                                                                                                                                 |
| 26:25            | R          | 0           | USB Line Status<br>[26]-DM<br>[27]-DP                                                                                                                                                                          |
| 24               | R          | 0           | USB VBUS Status<br>These filed indicate the VBUS status.                                                                                                                                                       |
| 23:18            | R/W        | 0           | Forcerid<br>1xxxxx: Force the ID value of bit[22:18] output to SIE<br>0xxxxx: Select phy output the ID value to SIE                                                                                            |
| 17:16            | /          | /           | /                                                                                                                                                                                                              |
| 15:14            | R/W        | 0           | Force ID<br>0x: use external ID Status<br>10: force ID to LOW<br>11: force ID to HIGH                                                                                                                          |
| 13:12            | R/W        | 0           | Force VBUS Valid (For SIE)<br>0x: use external VBUS Valid Status from VBUS Input or Line State<br>10: force VBUS Valid to LOW<br>11: force VBUS Valid to HIGH                                                  |
| 11:10            | R/W        | 0           | External VBUS Valid Source Select<br>0x: External VBUS Valid detected from VBUS Input<br>10: External VBUS Valid detected from DP/DM Input<br>11: External VBUS Valid detected from either VBUS or DP/DM input |
| 9                | R/W        | 0           | USB Wakeup Enable<br>0: Disable<br>1: Enable                                                                                                                                                                   |
| 8                | R/W        | 0           | USB Wakeup HOSC Enable<br>0: Disable<br>1: Enable                                                                                                                                                              |
| 7                | R/W1C      | 0           | USB ID Mult Value Change Interrupt Status                                                                                                                                                                      |

| Offset: 0x100000 |            |             | Register Name:USB2_ISCR                                                     |
|------------------|------------|-------------|-----------------------------------------------------------------------------|
| Bit              | Read/Write | Default/Hex | Description                                                                 |
|                  |            |             | 0 :No Change<br>1: Has Change                                               |
| 6                | R/W1C      | 0           | VBUS Input Change Detect Interrupt Status<br>0 :No Change<br>1: Has Change  |
| 5                | R/W1C      | 0           | ID Input Change Detect Interrupt Status<br>0 :No Change<br>1: Has Change    |
| 4                | R/W1C      | 0           | DP/DM Input Change Detect Interrupt Status<br>0 :No Change<br>1: Has Change |
| 3                | R/W        | 0           | USB ID Mult Value Detect Enable<br>0 :Disable<br>1: Enable                  |
| 2                | R/W        | 0           | VBUS Input Change Detect Interrupt Enable<br>0: Disable<br>1: Enable        |
| 1                | R/W        | 0           | ID Input Change Detect Interrupt Enable<br>0: Disable<br>1: Enable          |
| 0                | R/W        | 0           | DP/DM Input Change Detect Interrupt Enable<br>0: Disable<br>1: Enable       |

#### 8.11.8.2 0x100010 USB2.0 PHY Control Register (Default Value: 0x0000\_0018)

| Offset: 0x100010 |            |             | Register Name: USB2_PHYCTL |
|------------------|------------|-------------|----------------------------|
| Bit              | Read/Write | Default/Hex | Description                |
| 31:21            | /          | /           | /                          |
| 10               | R/W        | 0x0         | OTGDISABLE                 |
| 9                | R/W        | 0x0         | DRVVBUS                    |
| 8                | R/W        | 0x0         | VREGBYPASS                 |
| 7                | R/W        | 0x0         | LOOPBACKENB                |
| 6                | R/W        | 0x0         | IDPULLUP                   |
| 5                | R/W        | 0x0         | VBUSVLDEXT                 |
| 4                | R/W        | 0x1         | VBUSVLDEXTSEL              |
| 3                | R/W        | 0x1         | SIDDQ                      |
| 2                | R/W        | 0x0         | COMMONONN                  |
| 1:0              | R/W        | 0x0         | VATESTENB                  |

#### 8.11.8.3 0x100014 USB2.0 PHY TEST Register (Default Value: 0x0000\_0000)

| Offset: 0x100014 |            |             | Register Name: USB2_PHYTST |
|------------------|------------|-------------|----------------------------|
| Bit              | Read/Write | Default/Hex | Description                |
| 31:15            | /          | /           | /                          |
| 14               | R/W        | 0x0         | TESTBURNIN                 |
| 13               | R/W        | 0x0         | TESTDATAOUTSEL             |
| 12               | R/W        | 0x0         | TESTCLK                    |
| 11:8             | R/W        | 0x0         | TESTADDR[3:0]              |
| 7:0              | R/W        | 0x0         | TESTDATAIN[7:0]            |

#### 8.11.8.4 0x100018 USB2.0 PHY Tune Register (Default Value: 0x05B3\_33D4)

| Offset: 0x100018 |            |             | Register Name: USB2_PHYTUNE |
|------------------|------------|-------------|-----------------------------|
| Bit              | Read/Write | Default/Hex | Description                 |
| 31:28            | /          | /           | /                           |
| 27:26            | R/W        | 0x1         | VDATREFTUNE[1:0]            |
| 25:23            | R/W        | 0x3         | COMPDISTUNE[2:0]            |
| 22:20            | R/W        | 0x3         | SQRXTUNE[2:0]               |
| 19               | R/W        | 0x0         | TXPREEMPPULSETUNE           |
| 18:16            | R/W        | 0x3         | OTGTUNE[2:0]                |
| 15:12            | R/W        | 0x3         | TXFSLSTUNE[3:0]             |
| 11:8             | R/W        | 0x3         | TXVREFTUNE[3:0]             |
| 7:6              | R/W        | 0x3         | TXHSXVTUNE[1:0]             |
| 5:4              | R/W        | 0x1         | TXRISETUNE[1:0]             |
| 3:2              | R/W        | 0x1         | TXRESTUNE[1:0]              |
| 1:0              | R/W        | 0x0         | TXPREEMPAMPTUNE[1:0]        |

#### 8.11.8.5 0x100024 USB2.0 PHY Status Register (Default Value: 0x0000\_0000)

| Offset: 0x100024 |            |             | Register Name: USB2_PHYSTS |
|------------------|------------|-------------|----------------------------|
| Bit              | Read/Write | Default/Hex | Description                |
| 31:4             | /          | /           | /                          |
| 3:0              | R          | 0x0         | TESTDATAOUT[3:0]           |

## 8.12 PCIe2.1

### 8.12.1 Overview

The PCI Express Controller (PCIe) is a general purpose I/O interconnect, which provides low pin count, high reliability, and high-speed data transfer at rates of up to 5.0 Gbps per lane per direction.

Complies with PCI Express Base 2.1 Specification

The PCIe controller includes the following features:

- All non-optional features of the PCI Express Base Specification, Revision 2.1
- Supports Gen1(2.5 Gbit/s), Gen2 (5.0 Gbit/s) speed
- Only supports Root Complex (RC) mode
- Up to 1 lane link width
- Configurable max\_payload\_size and supports 1024 bytes
- Internal Address Translation Unit (iATU) supports 8 inbound and 8 outbound address translation regions
- Embedded DMA with hardware flow control supports 4 write/read channels.
- MSI with Per-Vector Masking (PVM) and extended message data for MSI
- PCI Express Active State Power Management (ASPM)
- PCI Express Advanced Error Reporting (AER)

### 8.12.2 Block Diagram

The following figure shows the functional block diagram of the PCIe.

**Figure 8-42 PCIe Block Diagram**



The PCIe controller contains the following modules:

**Table 8-32 PCIe Module**

| Module                                       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Common Express Port Logic (CXPL)             | This module implements the basic functionality for the PCI Express physical, link, and transaction layers. The CXPL implements a large part of the transaction layer logic, all of the data link layer logic, and the MAC portion of the physical layer, including the link training and status state machine (LTSSM). The CXPL connects to the external PHY through the PIPE.                                                                                                                                                                                                                                                          |
| Transmit Application-Dependent Module (XADM) | This module implements the application-specific functionality of the PCI Express transaction layer for packet transmission. Its functions include: <ul style="list-style-type: none"> <li>• TLP Arbitration</li> <li>• TLP Formation</li> <li>• Flow Control (FC) Credit checking</li> </ul> The transmit path uses a cut-through architecture. It does not implement transmit buffering/queues (other than the retry buffer). The controller maintains an internal Target Completion Lookup Table to store certain TLP header information from the Rx request. Your application can use this information for transmitting completions. |
| Receive Application-Dependent Module (RADM)  | This module implements application-specific functionality of the PCI Express transaction layer for packet reception. Its functions include:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

| Module                                                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                         | <ul style="list-style-type: none"> <li>Sorting/filtering of received TLPs. The filtering rules and routing are configurable.</li> <li>Buffering and queuing of the received TLPs.</li> <li>Routing of received TLP to the controller's receive interfaces.</li> </ul> <p>The RADM maintains a Receive Completion Lookup Table (LUT) for completion tracking and completion-timeout monitoring of Tx non-posted requests. It indicates a timeout when an expected Rx completion does not arrive within the timeout period.</p> |
| Configuration-Dependent Module (CDM)                    | <p>This module implements:</p> <ul style="list-style-type: none"> <li>Standard PCI Express configuration space</li> <li>Controller-specific register space (Port Logic Registers)</li> </ul>                                                                                                                                                                                                                                                                                                                                  |
| Power Management Controller (PMC)                       | This module implements the power management features of the PCIe controller.                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| Local Bus Controller (LBC) and Data Bus Interface (DBI) | <p>The LBC module provides a mechanism for a link partner (in EP mode only) or a local CPU (through the DBI) to access:</p> <ul style="list-style-type: none"> <li>Internal registers (in the CDM)</li> <li>External application registers connected externally to the ELBI</li> </ul>                                                                                                                                                                                                                                        |
| Message Generation Module (MSG_GEN)                     | This module transmits messages generated by the controller.                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Integrated MSI Receiver (iMSI-RX)                       | The AXI bridge provides an integrated MSI reception module to detect and terminate inbound MSI requests(received on the RX wire).                                                                                                                                                                                                                                                                                                                                                                                             |
| Embedded DMA (eDMA)                                     | The RC system CPU, or the EP application CPU, can offload the transferring of large blocks of data to the embedded DMA controller1, leaving the CPU free to perform other tasks. You can configure the DMA to have one to eight read channels and one to eight write channels.                                                                                                                                                                                                                                                |
| Internal Address Translation Unit (iATU)                | The PCIe controller uses the iATU to implement a local address translation scheme that replaces the TLP address and TLP header fields in the current TLP request header.                                                                                                                                                                                                                                                                                                                                                      |

### 8.12.3 Functional Description

#### 8.12.3.1 External Signals

The following table describes the external signals of the PCIe.

Table 8-33 PCIe External Signals

| Signal Name   | Description                                   | Type  |
|---------------|-----------------------------------------------|-------|
| PCIE-REF-CLKN | PCIe2.1 Differential Signal REFCLK (Negative) | A I/O |
| PCIE-REF-CLKP | PCIe2.1 Differential Signal REFCLK (Positive) | A I/O |
| PCIE-REXT     | PCIe2.1 External Reference Resistor           | AO    |

| Signal Name   | Description                                  | Type  |
|---------------|----------------------------------------------|-------|
| PCIE-RX0-DN   | PCIe2.1 Differential Signal of RX (Negative) | A I/O |
| PCIE-RX0-DP   | PCIe2.1 Differential Signal of RX (Positive) | A I/O |
| PCIE-TX0-DN   | PCIe2.1 Differential Signal of TX (Negative) | A I/O |
| PCIE-TX0-DP   | PCIe2.1 Differential Signal of TX (Positive) | A I/O |
| PCIE0-PERSTN  | PCIe2.1 Warm Reset                           | O     |
| PCIE0-WAKEN   | PCIe2.1 Wake Up                              | I     |
| PCIE0-CLKREQN | PCIe2.1 Clock Request from PCIe Peripheral   | I     |
| VCC18-PCIE    | 1.8 V Power Supply for PCIe2.1               | P     |
| VDD09-PCIE    | 0.9 V Power Supply for PCIe2.1               | P     |

### 8.12.3.2 Clock Sources

The following table describes the clock sources of the PCIe.

**Table 8-34 PCIe Clock Sources**

| Clock Sources     | Description                                                                                 | Module |
|-------------------|---------------------------------------------------------------------------------------------|--------|
| USB3_PCIE_REF_CLK | 24 MHz, USB3.1 DRD&Pcie2.1 PHY reference clock.                                             | CCU    |
| AUX_CLK           | 24 MHz, working clock in low power mode of the PCIe.                                        |        |
| MBUS_CLK          | 600 MHz, PCIe AXI master/slave bus clock.                                                   |        |
| AHB_CLK           | 200 MHz, PCIe bus clock.                                                                    |        |
| PIPE_CLK          | 62.5 MHz/ 125MHz, normal working clock for the PCIe controller operating in Gen1/Gen2 mode. |        |

### 8.12.3.3 PCIe Reference Clock

PCIe reference clock is a 100M differential clock supplied for the PCIe PHY. There are two clock sources.

- From Internal SoC

Configure PHY to use internal clock and enable the clock output via software. The REFCLKP/REFCLKN signal of PCIe controller serves as output signal and provides 100M differential clock for external EP.

- From External Clock Generator

Configure PHY to use external clock and disable the clock output via software. The REFCLKP/REFCLKN signal of PCIe controller serves as input signal and the external clock generator provides 100M differential clock for PHY.

### 8.12.3.4 PCIe Memory Mapping

The address space of PCIe controller can be partitioned into three spaces.

- Core Configuration Space (CCS): The configuration register space of the PCIe controller itself. It is also the standard configuration register space defined by the PCIe specification.
- User Defined Space (UDS): The custom register space for the PCIe controller itself.
- Slave Command Space (SCS): Address space for configuration transaction and memory transaction. The read and write operations of this space will be transformed by the PCIe controller into configuration read and write transactions or memory read and write transactions in PCIe domain. The PCIe command space segmentation is 0x20000000-0x2FFFFFFF.

### 8.12.3.5 ATU Operation

ATU is an address translation unit in PCIe controller and is used for transaction transformation and address translation. There are two types of ATU: Outbound ATU and Inbound ATU.

#### Outbound ATU

Outbound ATU is used to transform the read/write operation in CPU domain of the original address space into the read/write transaction in PCIe domain of the target address space. If the Outbound ATU is used, the original address in the CPU domain will be translated into another different address in the PCIe domain. If the Outbound ATU is not used, the PCIe controller will not perform address translation. The read/write operation initiated in the CPU domain will be transformed into the read/write transaction at the same address in the PCIe domain.

The following shows an example:

- When Outbound ATU is used, set address Region N in the CPU domain to be translated into Region K in PCIe domain. The read/write operation initiated at address Region N (CPU domain) will be transformed into the read/write transaction at address Region K (PCIe domain).
- When Outbound ATU is not used, read/write operation initiated at address Region N (CPU domain) will be transformed into the read/write transaction at address Region N (PCIe domain).

**Figure 8-43 Outbound ATU**

### Inbound ATU

Inbound ATU is used to transform the read/write transaction in the PCIe domain of the original address space into the read/write operation in the CPU domain of the target address space. If Inbound ATU is used, the original address in the PCIe domain will be translated into another different address in the CPU domain. If the Inbound ATU is not used, the PCIe controller will not perform address translation. The read/write transaction initiated in the PCIe domain will be transformed into the read/write operation at the same address in the CPU domain.

The following shows an example:

- When Inbound ATU is used, set address Region N in the PCIe domain to be translated into Region K in the CPU domain. The read/write transaction initiated at address Region N (PCIe domain) will be transformed into the read/write operation at address Region K (CPU domain).
- When Inbound ATU is not used, read/write transaction initiated at address Region N (PCIe domain) will be transformed into the read/write operation at address Region N (CPU domain).

**Figure 8-44 Inbound ATU**

#### 8.12.3.6 DMA Operation

There is a private DMA with read channels and write channels in the PCIe controller. The following figure describes the DMA write and read process.

**Figure 8-45 DMA Operation**

- **DMA Write Channel**

the DMA write channel is used for data transfer from local bus address space to the address space in the PCIe domain. First, DMA controller reads data from the local bus address space and writes them to the address space in the CPU domain. Then, the PCIe controller transforms the write operation initiated by DMA into a write transaction in the PCIe domain and writes data to the destination address space in the PCIe domain.

- DMA Read Channel

The DMA read channel is used for data transfer from the address space in the PCIe domain to the local bus address space such as DRAM address space. If a read operation is initiated by DMA in the original address space of the CPU domain, the PCIe controller will transform the read operation into a read transaction in the PCIe domain and write data to the local bus address space.

#### 8.12.3.7 MSI Operation

Message Signaled Interrupt (MSI) is a kind of mechanism that Endpoints send interrupt requests to the CPU connected with the Root Complex, which uses memory write transaction. The transaction message for transmitting interrupt information is MSI message.

Assume an Endpoint needs to send a MSI interrupt request to CPU. First, the Endpoint needs to initiate a memory write transaction in MSI address of PCIe domain, which will be transformed into a MSI interrupt signal to CPU by the PCIe controller after the transaction is detected. Software obtains the Endpoint sending interrupt request and its interrupt vector according to the MSI message.

#### 8.12.4 Register List

| Module Name | Base Address |
|-------------|--------------|
| PCIE        | 0x04800000   |

| Register Class         | Offset                  |
|------------------------|-------------------------|
| User Defined Registers | 0x00400000 - 0x0047FFFF |

| Register Name               | Offset | Description                                              |
|-----------------------------|--------|----------------------------------------------------------|
| MSTR_AWMISC_INFO_0          | 0x0100 | PCIE AXI Master Write Misc Information Register0         |
| MSTR_AWMISC_INFO_1          | 0x0104 | PCIE AXI Master Write Misc Information Register1         |
| MSTR_AWMISC_INFO_HDR_34DW_0 | 0x0108 | PCIE AXI Master Write Misc Information Header Register0  |
| MSTR_AWMISC_INFO_HDR_34DW_1 | 0x010C | PCIE AXI Master Write Misc Information Header Register1  |
| MSTR_AWMISC_INFO_OTHER      | 0x0110 | PCIE AXI Master Write Misc Information Other Register    |
| MSTR_ARMISC_INFO_0          | 0x0120 | PCIE AXI Master Read Misc Information Register0          |
| MSTR_ARMISC_INFO_1          | 0x0124 | PCIE AXI Master Read Misc Information Register1          |
| MSTR_ARMISC_INFO_OTHER      | 0x0130 | PCIE AXI Master Read Misc Information Other Register     |
| MSTR_BMISC_INFO             | 0x0150 | PCIE AXI Master Write Response Misc Information Register |

| Register Name              | Offset | Description                                             |
|----------------------------|--------|---------------------------------------------------------|
| MSTR_RMISC_INFO            | 0x0160 | PCIE AXI Master Read Misc Information Register          |
| PCIE_SLV_AWMISC_CTRL       | 0x0200 | PCIE Write Transaction Control Register                 |
| SLV_AWMISC_INFO_ATU_BY_P   | 0x0204 | PCIE AXI SLAVE Write Misc Information ATU Register      |
| SLV_AWMISC_INFO_HDR_34DW_0 | 0x0208 | PCIE AXI SLAVE Write Misc Information Header Register0  |
| SLV_AWMISC_INFO_HDR_34DW_1 | 0x020C | PCIE AXI SLAVE Write Misc Information Header Register1  |
| SLV_AWMISC_INFO_OTHER_0    | 0x0210 | PCIE AXI SLAVE Write Misc Information Other Register0   |
| SLV_AWMISC_INFO_OTHER_1    | 0x0214 | PCIE AXI SLAVE Write Misc Information Other Register1   |
| SLV_ARMISC_CTRL            | 0x0220 | PCIE AXI SLAVE Read Control Register                    |
| SLV_ARMISC_INFO_ATU_BY_P   | 0x0224 | PCIE AXI SLAVE Read Misc Information ATU Register       |
| SLV_ARMISC_INFO_OTHER      | 0x0230 | PCIE AXI SLAVE Read Misc Information Other Register     |
| SLV_BMISC_INFO             | 0x0250 | PCIE AXI Slave Write Response Misc Information Register |
| SLV_RMISC_INFO             | 0x0260 | PCIE AXI Slave Read Response Misc Information Register  |
| APP_CLK_REQ_N              | 0x0400 | PCIE APP Clock Request Register                         |
| APP_INIT_RST               | 0x0500 | PCIE APP Initial Reset Register                         |
| VEN_MSG_REQ                | 0x0700 | PCIE VEN MSG Request Register                           |
| VEN_MSG_CFG_0              | 0x0704 | PCIE VEN MSG Config Register0                           |
| VEN_MSG_CFG_1              | 0x0708 | PCIE VEN MSG Config Register1                           |
| VEN_MSG_DATA_0             | 0x070C | PCIE VEN MSG Data Register0                             |
| VEN_MSG_DATA_1             | 0x0710 | PCIE VEN MSG Data Register1                             |
| SII_ELEC                   | 0xA00  | PCIE SII Electromechanical Register                     |
| FRS_READY                  | 0xB04  | PCIE FRS READY Register                                 |
| PCIE_LTSSM_ENABLE          | 0xC00  | PCIE LTSSM Enable Register                              |
| SII_INT_MASK_0             | 0xE00  | PCIE SII Interrupt Mask Register0                       |
| SII_INT_MASK_1             | 0xE04  | PCIE SII Interrupt Mask Register1                       |
| SII_INT_0                  | 0xE08  | PCIE SII Interrupt Register0                            |
| SII_INT_1                  | 0xE0C  | PCIE SII Interrupt Register1                            |
| SII_APP_PM_UNLOCK          | 0x1000 | PCIE SII APP PM UNLOCK Register                         |
| SII_APP_PM_0               | 0x1100 | PCIE SII Power Manage Register0                         |

### 8.12.5 Register Description

#### 8.12.5.1 0x0100 PCIE AXI Master Write Misc Information Register0 (Default Value: 0x0000\_0000)

| Offset: 0x0100 |            |             | Register Name: MSTR_AWMISC_INFO_0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 31:0           | R          | 0x0         | <p>MSTR_AWMISC_INFO_0<br/>AXI Master Write Misc Information.<br/>AXI master write transaction associated<br/>miscellaneous information from the TLP received by<br/>the native PCIe controller. This is a signal that the<br/>application can optionally use. It is not part of the<br/>standard AXI interface.</p> <ul style="list-style-type: none"> <li>• Bus number, device number, function number,<br/>and register numbers are overlaid to the address<br/>bus when type is configuration transactions.</li> <li>• Message contents are also overlaid to the<br/>address bus for MSG TLPs. Bits [7:0] indicate the<br/>message code when the type is message.</li> </ul> <p>The bit fields are mapped as follows:</p> <ul style="list-style-type: none"> <li>• [7:0]: Reserved except for MSG TLP. Bits [7:0]<br/>indicate the message code when the type is<br/>message.</li> <li>• [8:6]: BAR number of TLP</li> <li>• [9]: TLP is an I/O</li> <li>• [10]: TLP is in ROM range</li> <li>• [13:11]: TLP's Function number. Function<br/>numbering starts at '0'.<br/>This field is not used when CX_SRIOV_ENABLE =1<br/>or CX_ARI_ENABLE =1.</li> <li>• [14]: TLP's NS bit</li> <li>• [15]: TLP's RO bit</li> <li>• [18:16]: TLP's TC bits</li> <li>• [23:19]: TLP's TYPE</li> <li>• 31:24]: TLP's requester ID_0</li> </ul> |

#### 8.12.5.2 0x0104 PCIE AXI Master Write Misc Information Register1 (Default Value: 0x0000\_0000)

| Offset: 0x0104 |            |             | Register Name: MSTR_AWMISC_INFO_1                                         |
|----------------|------------|-------------|---------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                               |
| 31:16          | /          | /           | /                                                                         |
| 15:0           | R          | 0x0         | MSTR_AWMISC_INFO_1<br>AXI Master Write Misc Information. AXI master write |

| Offset: 0x0104 |            |             | Register Name: MSTR_AWMISC_INFO_1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                |            |             | <p>transaction associated miscellaneous information from the TLP received by the native PCIe controller. This is a signal that the application can optionally use. It is not part of the standard AXI interface.</p> <ul style="list-style-type: none"> <li>• Bus number, device number, function number, and register numbers are overlaid to the address bus when type is configuration transactions.</li> <li>• Message contents are also overlaid to the address bus for MSG TLPs. Bits [7:0] indicate the message code when the type is message.</li> </ul> <p>The bit fields are mapped as follows:</p> <p>[8:0]: TLP's requester ID_1<br/> [15:9]: TLP's TAG</p> |

#### 8.12.5.3 0x0108 PCIE AXI Master Write Misc Information Header Register0 (Default Value: 0x0000\_0000)

| Offset: 0x0108 |            |             | Register Name: MSTR_AWMISC_INFO_HDR_34DW_0                            |
|----------------|------------|-------------|-----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                           |
| 31:0           | R          | 0x0         | MSTR_AWMISC_INFO_HDR_34DW_0<br>mstr_awmisc_info_hdr_34dw_status[31:0] |

#### 8.12.5.4 0x010C PCIE AXI Master Write Misc Information Header Register1 (Default Value: 0x0000\_0000)

| Offset: 0x010C |            |             | Register Name: MSTR_AWMISC_INFO_HDR_34DW_1                             |
|----------------|------------|-------------|------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                            |
| 31:0           | R          | 0x0         | MSTR_AWMISC_INFO_HDR_34DW_1<br>mstr_awmisc_info_hdr_34dw_status[63:32] |

#### 8.12.5.5 0x0110 PCIE AXI Master Write Misc Information Other Register (Default Value: 0x0000\_0000)

| Offset: 0x0110 |            |             | Register Name: MSTR_AWMISC_INFO_OTHER                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                             |
| 31:28          | /          | /           | /                                                                       |
| 27             | R          | 0x0         | MSTR_AWMISC_INFO_LAST_DCMP_TLP<br>mstr_awmisc_info_last_dcmp_tlp_status |
| 26             | R          | 0x0         | MSTR_AWMISC_INFO_EP<br>mstr_awmisc_info_ep_status                       |
| 25             | R          | 0x0         | MSTR_AWMISC_INFO_NW<br>mstr_awmisc_info_nw_status                       |

| Offset: 0x0110 |            |             | Register Name: MSTR_AWMISC_INFO_OTHER                     |
|----------------|------------|-------------|-----------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                               |
| 24             | R          | 0x0         | MSTR_AWMISC_INFO_IDO<br>mstr_awmisc_info_ido_status       |
| 23:22          | R          | 0x0         | MSTR_AWMISC_INFO_ATS<br>mstr_awmisc_info_ats_status[1:0]  |
| 21:16          | R          | 0x0         | MSTR_AWMISC_INFO_DMA<br>mstr_awmisc_info_dma_status[5:0]  |
| 15:11          | /          | /           | /                                                         |
| 10:0           | R          | 0x0         | MSTR_AWMISC_INFO_TPH<br>mstr_awmisc_info_tph_status[10:0] |

#### 8.12.5.6 0x0120 PCIE AXI Master Read Misc Information Register0 (Default Value: 0x0000\_0000)

| Offset: 0x0120 |            |             | Register Name: MSTR_ARMISC_INFO_0                   |
|----------------|------------|-------------|-----------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                         |
| 31:0           | R          | 0x0         | MSTR_ARMISC_INFO_0<br>mstr_armisc_info_status[31:0] |

#### 8.12.5.7 0x0124 PCIE AXI Master Read Misc Information Register1 (Default Value: 0x0000\_0000)

| Offset: 0x0124 |            |             | Register Name: MSTR_ARMISC_INFO_1                    |
|----------------|------------|-------------|------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                          |
| 31:16          | /          | /           | /                                                    |
| 15:0           | R          | 0x0         | MSTR_ARMISC_INFO_1<br>mstr_armisc_info_status[47:32] |

#### 8.12.5.8 0x0130 PCIE AXI Master Read Misc Information Other Register (Default Value: 0x0000\_0000)

| Offset: 0x0130 |            |             | Register Name: MSTR_ARMISC_INFO_OTHER                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                             |
| 31:29          | /          | /           | /                                                                       |
| 28             | R          | 0x0         | MSTR_ARMISC_INFO_ZEROREAD<br>mstr_armisc_info_zeroread_status           |
| 27             | R          | 0x0         | MSTR_ARMISC_INFO_LAST_DCMP_TLP<br>mstr_armisc_info_last_dcmp_tlp_status |
| 26             | /          | /           | /                                                                       |
| 25             | R          | 0x0         | MSTR_ARMISC_INFO_NW<br>mstr_armisc_info_nw_status                       |
| 24             | R          | 0x0         | MSTR_ARMISC_INFO_IDO<br>mstr_armisc_info_ido_status                     |

| Offset: 0x0130 |            |             | Register Name: MSTR_ARMISC_INFO_OTHER                     |
|----------------|------------|-------------|-----------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                               |
| 23:22          | /          | /           | /                                                         |
| 21:16          | R          | 0x0         | MSTR_ARMISC_INFO_DMA<br>mstr_armisc_info_dma_status[5:0]  |
| 15:11          | /          | /           | /                                                         |
| 10:0           | R          | 0x0         | MSTR_ARMISC_INFO_TPH<br>mstr_armisc_info_tph_status[10:0] |

#### 8.12.5.9 0x0150 PCIE AXI Master Write Response Misc Information Register (Default Value: 0x0000\_0000)

| Offset: 0x0150 |            |             | Register Name: MSTR_BMISC_INFO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 31:2           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 1:0            | R/W        | 0x0         | <p>MSTR_BMISC_INFO_CPL_STAT<br/>AXI Master Write Response selection bus. This controls the response to be sent on the wire in the case of successful write requests. The controller always sends a CA (Completer Abort) response when it receives SLVERR/DECERR.</p> <ul style="list-style-type: none"> <li>▪ 00: SC (Successful Completion)</li> <li>▪ 01: CA (Completer Abort)</li> <li>▪ 10: UR (Unsupported Request)</li> <li>▪ 11: SC (Successful Completion)</li> </ul> <p>Your application must drive the same value on mstr_bmisc_info_cpl_stat throughout the complete response. For a multi-beat response, when you set mstr_bmisc_info_cpl_stat to UR:</p> <ul style="list-style-type: none"> <li>▪ If the first beat of the response produces a slave error/decode error, the controller sends a CPL with status as CA.</li> <li>▪ If any beat (other than the first beat) of the response has a slave/decode error, the controller sends a CPL with status as UR.</li> </ul> |

#### 8.12.5.10 0x0160 PCIE AXI Master Read Misc Information Register (Default Value: 0x0000\_0000)

| Offset: 0x0160 |            |             | Register Name: MSTR_RMISC_INFO                                               |
|----------------|------------|-------------|------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                  |
| 31:18          | /          | /           | /                                                                            |
| 17:16          | R/W        | 0x0         | MSTR_RMISC_INFO_CPL_STAT<br>AXI Master Read Response selection bus. This bus |

| Offset: 0x0160 |            |             | Register Name: MSTR_RMISC_INFO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                |            |             | <p>controls the response sent on the PCIe wire in the case of successful read requests. The controller always sends a CA (Completer Abort) response when it receives SLVERR/DECERR.</p> <ul style="list-style-type: none"> <li>▪ 00: SC (Successful Completion)</li> <li>▪ 01: CA (Completer Abort)</li> <li>▪ 10: UR (Unsupported Request)</li> <li>▪ 11: SC (Successful Completion)</li> </ul> <p>Your application must drive the same value on mstr_rmisc_info_cpl_stat throughout the complete response. For a multi-beat response, when you set mstr_rmisc_info_cpl_stat to UR:</p> <ul style="list-style-type: none"> <li>▪ If the first beat of the response produces a slave error/decode error, the controller sends a CPL with status as CA.</li> <li>▪ If any beat (other than the first beat) of the response has a slave/decode error, the controller sends a CPL with status as UR.</li> </ul> |
| 15:13          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 12:0           | R/W        | 0x0         | <p>MSTR_RMISC_INFO<br/>AXI Master Read Response Transaction Associated Misc Information. This is a signal that the application can optionally use. It is not part of standard AXI interface. All reserved bits must be connected to logic '0'.</p> <ul style="list-style-type: none"> <li>▪ [1:0]: Reserved</li> <li>▪ [2]: Reserved.</li> <li>▪ [6:3]: Reserved</li> <li>▪ [7]: TLP's EP bit</li> <li>▪ [12:8]: Reserved.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

#### 8.12.5.11 0x0200 PCIE SLAVE Write Msic Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0200 |            |             | Register Name: PCIE_SLV_AWMISC_CTRL                                |
|----------------|------------|-------------|--------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                        |
| 31:22          | /          | /           | /                                                                  |
| 21             | R/W        | 0x0         | AXI transaction is a DBI access. This is for SHARED DBI mode only. |
| 20:13          | R/W        | 0x00        | MSG<br>MSG Code of TLPs                                            |

| Offset: 0x0200 |            |             | Register Name: PCIE_SLV_AWMISC_CTRL       |
|----------------|------------|-------------|-------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                               |
| 12:10          | R/W        | 0x0         | TC<br>TC bits of TLPs                     |
| 9              | R/W        | 0x0         | RO<br>RO bit of TLPs                      |
| 8              | R/W        | 0x0         | NS<br>NS bit of TLPs                      |
| 7              | /          | /           | /                                         |
| 6              | R/W        | 0x0         | EP<br>EP bit of TLPs                      |
| 5              | R/W        | 0x0         | SERIALIZE_NP_REQ<br>Serialize NP Requests |
| 4:0            | R/W        | 0x0         | TYPE<br>Type of TLPs                      |

#### 8.12.5.12 0x0204 PCIE AXI SLAVE Write Misc Information ATU Register (Default Value: 0x0000\_0000)

| Offset: 0x0204 |            |             | Register Name: SLV_AWMISC_INFO_ATU_BYP                                                                                                                                              |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                         |
| 31:1           | /          | /           | /                                                                                                                                                                                   |
| 0              | R/W        | 0x0         | SLV_AWMISC_INFO_ATU_BYPASS<br>AXI Slave Write Request Internal ATU Bypass. When set it indicates that this request should not be processed by the internal address translation unit |

#### 8.12.5.13 0x0208 PCIE AXI SLAVE Write Misc Information Header Register0 (Default Value: 0x0000\_0000)

| Offset: 0x0208 |            |             | Register Name: SLV_AWMISC_INFO_HDR_34DW_0                                                                                                                                                                                                                                                                               |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                             |
| 31:0           | R/W        | 0x0         | SLV_AWMISC_INFO_HDR_34DW_0<br>slv_awmisc_info_hdr_34dw[31:0] ,AXI Slave 3rd and 4th header DWs. The application drives this bus with the 3rd and 4th Header DWs it intends to send on a PCIe Msg/MsgD.<br>Note: The data is in big endian format, that is, slv_awmisc_info_hdr_34dw[7:0] contains byte 15 of header DW. |

#### 8.12.5.14 0x020C PCIE AXI SLAVE Write Misc Information Header Register1 (Default Value: 0x0000\_0000)

| Offset: 0x020C |            |             | Register Name: SLV_AWMISC_INFO_HDR_34DW_1                                                                                                                                                                                                                                |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                              |
| 31:0           | R/W        | 0x0         | <p>SLV_AWMISC_INFO_HDR_34DW_1<br/> slv_awmisc_info_atu_bypass[63:32] ,AXI Slave 3rd and 4th header DWs. The application drives this bus with the 3rd and 4th Header DWs it intends to send on a PCIe Msg/MsgD.</p> <p><b>Note:</b> The data is in big endian format.</p> |

#### 8.12.5.15 0x0210 PCIE AXI SLAVE Write Misc Information Other Register0 (Default Value: 0x0000\_0000)

| Offset: 0x0210 |            |             | Register Name: SLV_AWMISC_INFO_OTHER_0                                                                                                                                                                                                                                                |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                           |
| 31:26          | /          | /           | /                                                                                                                                                                                                                                                                                     |
| 25             | R/W        | 0x0         | <p>SLV_AWMISC_INFO_NW<br/> AXI Slave Write Transaction's Request ATS No Write (NW) Bit. This is a signal that the application can optionally use. It is not part of the standard AXI interface.</p>                                                                                   |
| 24             | R/W        | 0x0         | <p>SLV_AWMISC_INFO_IDO<br/> AXI Slave Write Transaction's IDO bit. Enables ID-base ordering on outbound requests. This is a signal that the application can optionally use. It is not part of the standard AXI interface.</p>                                                         |
| 23:11          | /          | /           | /                                                                                                                                                                                                                                                                                     |
| 10:0           | R/W        | 0x0         | <p>SLV_AWMISC_INFO_TPH<br/> AXI Slave Write Request TLP Processing Hints. The bits are mapped as follows:</p> <ul style="list-style-type: none"> <li>▪ [0]: TH (TLP Processing Hint present)</li> <li>▪ [2:1] PH (TLP Processing Hint)</li> <li>▪ [10:3] ST (Steering Tag)</li> </ul> |

#### 8.12.5.16 0x0214 PCIE AXI SLAVE Write Misc Information Other Register1 (Default Value: 0x0000\_0000)

| Offset: 0x0214 |            |             | Register Name: SLV_AWMISC_INFO_OTHER_1                                                                                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                             |
| 31:8           | /          | /           | /                                                                                                                                       |
| 7:0            | R/W        | 0x0         | <p>SLV_AWMISC_INFO_P_TAG<br/> AXI Slave Write Request Tag. Sets the TAG number for output posted requests. It is expected that your</p> |

| Offset: 0x0214 |            |             | Register Name: SLV_AWMISC_INFO_OTHER_1                                                |
|----------------|------------|-------------|---------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                           |
|                |            |             | application normally sets this to '0' except when generating ATS invalidate requests. |

#### 8.12.5.17 0x0220 PCIE AXI SLAVE Read Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0220 |            |             | Register Name: SLV_ARMISC_CTRL                                     |
|----------------|------------|-------------|--------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                        |
| 31:22          | /          | /           | /                                                                  |
| 21             | R/W        | 0x0         | AXI transaction is a DBI access. This is for SHARED DBI mode only. |
| 20:13          | R/W        | 0x00        | MSG<br>TLP's MSG Code                                              |
| 12:10          | R/W        | 0x0         | TC<br>TLP's TC bits                                                |
| 9              | R/W        | 0x0         | RO<br>TLP's RO bit                                                 |
| 8              | R/W        | 0x0         | NS<br>TLP's NS bit                                                 |
| 7              | /          | /           | /                                                                  |
| 6              | R/W        | 0x0         | EP<br>TLP's EP bit                                                 |
| 5              | /          | /           | /                                                                  |
| 4:0            | R/W        | 0x0         | TYPE<br>TLP's TYPE                                                 |

#### 8.12.5.18 0x0224 PCIE AXI SLAVE Read Misc Information ATU Register (Default Value: 0x0000\_0000)

| Offset: 0x0224 |            |             | Register Name: SLV_ARMISC_INFO_ATU_BYP                                                                                                                                             |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                        |
| 31:1           | /          | /           | /                                                                                                                                                                                  |
| 0              | R/W        | 0x0         | SLV_ARMISC_INFO_ATU_BYPASS<br>AXI Slave Read Request Internal ATU Bypass. When set it indicates that this request should not be processed by the internal address translation unit |

#### 8.12.5.19 0x0230 PCIE AXI SLAVE Read Misc Information Other Register (Default Value: 0x0000\_0000)

| Offset: 0x0230 |            |             | Register Name: SLV_ARMISC_INFO_OTHER |
|----------------|------------|-------------|--------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                          |

| Offset: 0x0230 |            |             | Register Name: SLV_ARMISC_INFO_OTHER                                                                                                                                                                                                                                    |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                             |
| 31:26          | /          | /           | /                                                                                                                                                                                                                                                                       |
| 25             | R/W        | 0x0         | SLV_ARMISC_INFO_NW<br>AXI Slave Read Transaction's Request AT No Write (NW) Bit. This is a signal that the application can optionally use. It is not part of the standard AXI interface.                                                                                |
| 24             | R/W        | 0x0         | SLV_ARMISC_INFO_IDO<br>AXI Slave Read Transaction's IDO bit. Enables ID-base ordering on outbound requests. This is a signal that the application can optionally use. It is not part of the standard AXI interface.                                                     |
| 23:11          | /          | /           | /                                                                                                                                                                                                                                                                       |
| 10:0           | R/W        | 0x0         | SLV_ARMISC_INFO_TPH<br>AXI Slave Read Request TLP Processing Hints. The bits are mapped as follows: <ul style="list-style-type: none"><li>▪ [0]: TH (TLP Processing Hint present)</li><li>▪ [2:1] PH (TLP Processing Hint)</li><li>▪ [10:3] ST (Steering Tag)</li></ul> |

#### 8.12.5.20 0x0250 PCIE AXI Slave Write Response Misc Information Register (Default Value: 0x0000\_0000)

| Offset: 0x0250 |            |             | Register Name: SLV_BMISC_INFO                  |
|----------------|------------|-------------|------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                    |
| 31:11          | /          | /           | /                                              |
| 10:0           | R          | 0x0         | SLV_BMISC_INFO_STATUS<br>slv_bmisc_info_status |

#### 8.12.5.21 0x0260 PCIE AXI Slave Read Response Misc Information Register (Default Value: 0x0000\_0000)

| Offset: 0x0260 |            |             | Register Name: SLV_RMISC_INFO                          |
|----------------|------------|-------------|--------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                            |
| 31:25          | /          | /           | /                                                      |
| 24             | R          | 0x0         | SLV_RMISC_INFO_IDO_STATUS<br>slv_rmisc_info_ido_status |
| 23:11          | /          | /           | /                                                      |
| 10:0           | R          | 0x0         | MSTR_RMISC_INFO<br>mstr_rmisc_info                     |

#### 8.12.5.22 0x0400 PCIE APP Clock Request Register (Default Value: 0x0000\_0000)

| Offset: 0x0400 |            |             | Register Name: APP_CLK_REQ_N                                                                                                                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                               |
| 31:1           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                         |
| 0              | R/W        | 0x0         | APP_CLK_REQ_N<br>Indicates that the application logic is ready to have reference clock removed. In designs which support reference clock removal through either L1 PM Sub-states or L1 CPM, the application should set this signal to 1'b when it is ready to have reference clock removed. If the application does not want to remove reference clock it should set this signal to 1'b0. |

#### 8.12.5.23 0x0500 PCIE APP Initial Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x0500 |            |             | Register Name: APP_INIT_RST                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 31:1           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0              | R/W        | 0x0         | APP_INIT_RST<br>app_init_rst_ahb<br>Request from your application to send a hot reset to the upstream port. The hot reset request is sent when a single cycle pulse is applied to this pin. In an upstream port, you should set this input to '0'. Note: This signal is not used by the controller to set the SBR field in the BRIDGE_CTRL_INT_PIN_INT_LINE_REG register. During the transition from DL_Active to DL_inactive, assertion of app_init_rst signal indicates a Surprise Down Error, but setting of SBR field in the BRIDGE_CTRL_INT_PIN_INT_LINE_REG register through DBI does not trigger a Surprise Down Error. |

#### 8.12.5.24 0x0700 PCIE VEN MSG Request Register (Default Value: 0x0000\_0000)

| Offset: 0x0700 |            |             | Register Name: VEN_MSG_REQ                                                                                     |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                    |
| 31:1           | /          | /           | /                                                                                                              |
| 0              | R/W        | 0x0         | VEN_MSG_REQ<br>ven_msG_req_ahb, Request from your application to send a vendor-defined Message. Once asserted, |

| Offset: 0x0700 |            |             | Register Name: VEN_MSG_REQ                                                   |
|----------------|------------|-------------|------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                  |
|                |            |             | ven_msg_req must remain asserted until the controller asserts ven_msg_grant. |

#### 8.12.5.25 0x0704 PCIE VEN MSG Config Register0 (Default Value: 0x0000\_0000)

| Offset: 0x0704 |            |             | Register Name: VEN_MSG_CFG_0                                                                                                                                                                                                 |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                  |
| 31:24          | R/W        | 0x0         | VEN_MSG_CODE<br>The Message Code for the vendor-defined Message TLP.                                                                                                                                                         |
| 23:16          | /          | /           | /                                                                                                                                                                                                                            |
| 15:13          | R/W        | 0x0         | VEN_MSG_ATTR<br>The Attributes field for the vendor-defined Message TLP.<br><ul style="list-style-type: none"> <li>▪ Width is three bits when CX_IDO_ENABLE =1</li> <li>▪ Width is two bits when CX_IDO_ENABLE =0</li> </ul> |
| 12:8           | R/W        | 0x0         | VEN_MSG_TYPE<br>The Type field for the vendor-defined Message TLP.                                                                                                                                                           |
| 7:6            | R/W        | 0x0         | VEN_MSG_FMT<br>The Format field for the vendor-defined Message TLP.<br>Should be set to 0x1.                                                                                                                                 |
| 5:3            | R/W        | 0x0         | VEN_MSG_TC<br>The Traffic Class field for the vendor-defined Message TLP.                                                                                                                                                    |
| 2              | R/W        | 0x0         | VEN_MSG_TD<br>The TLP Digest (TD) bit for the vendor-defined Message TLP, valid when ven_msg_req is asserted.                                                                                                                |
| 1              | R/W        | 0x0         | VEN_MSG_EP<br>The Poisoned TLP (EP) bit for the vendor-defined Message TLP.                                                                                                                                                  |
| 0              | /          | /           | /                                                                                                                                                                                                                            |

#### 8.12.5.26 0x0708 PCIE VEN MSG Config Register1 (Default Value: 0x0000\_0000)

| Offset: 0x0708 |            |             | Register Name: VEN_MSG_CFG_1                           |
|----------------|------------|-------------|--------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                            |
| 31:24          | /          | /           | /                                                      |
| 23:16          | R/W        | 0x0         | VEN_MSG_TAG<br>Tag for the vendor-defined Message TLP. |
| 15:13          | /          | /           | /                                                      |

| Offset: 0x0708 |            |             | Register Name: VEN_MSG_CFG_1                                                                                                           |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                            |
| 12:10          | R/W        | 0x0         | VEN_MSG_FUNC_NUM<br>Function Number for the vendor-defined Message TLP. Function numbering starts at '0'.                              |
| 9:0            | R/W        | 0x0         | VEN_MSG_LEN<br>The Length field for the vendor-defined Message TLP (indicates length of data payload in dwords). Should be set to 0x0. |

#### 8.12.5.27 0x070C PCIE VEN MSG Data Register0 (Default Value: 0x0000\_0000)

| Offset: 0x070c |            |             | Register Name: VEN_MSG_DATA_0                                                                                                                                                                                                 |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                   |
| 31:0           | R/W        | 0x0         | VEN_MSG_DATA_0<br>fourth dwords of the Vendor Defined Message header where: <ul style="list-style-type: none"><li>▪ Bytes 12-15 (fourth header dword)<br/>=ven_msg_data[31:0], where ven_msg_data[7:0]<br/>=byte 15</li></ul> |

#### 8.12.5.28 0x0710 PCIE VEN MSG Data Register1 (Default Value: 0x0000\_0000)

| Offset: 0x0710 |            |             | Register Name: VEN_MSG_DATA_1                                                                                                                                                         |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                           |
| 31:0           | R/W        | 0x0         | VEN_MSG_DATA_1<br>third dwords of the Vendor Defined Message header where: <ul style="list-style-type: none"><li>▪ Bytes 8-11 (third header dword)<br/>=ven_msg_data[63:32]</li></ul> |

#### 8.12.5.29 0x0A00 PCIE SII Electromechanical Register (Default Value: 0x0000\_0000)

| Offset: 0x0A00 |            |             | Register Name: SII_ELEC                                                                                                                                                                                   |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                               |
| 31:8           | /          | /           | /                                                                                                                                                                                                         |
| 7              | R/W        | 0x0         | SYS_EML_INTERLOCK_ENAGED<br>sys_eml_interlock_engaged [0] , System Electromechanical Interlock Engaged. Indicates whether the system electromechanical interlock is engaged and controls the state of the |

| Offset: 0x0A00 |            |             | Register Name: SII_ELEC                                                                                                                                                                                                                                                                                                                                    |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                |
|                |            |             | Electromechanical Interlock Status bit in the Slot Status register.                                                                                                                                                                                                                                                                                        |
| 6              | R/W        | 0x0         | SYS_CMD_CPLED_INT<br>sys_cmd_cpled_int[0] , Command completed Interrupt. Indicates that the Hot-Plug controller completed a command. There is a separate sys_cmd_cpled_int input bit for each function in your controller configuration                                                                                                                    |
| 5              | R/W        | 0x0         | SYS_PRE_DET_CHGED<br>sys_pre_det_chged[0]<br>Presence Detect Changed. Indicates that the state of card present detector has changed. There is a separate sys_pre_det_chged input bit for each function in your controller configuration.                                                                                                                   |
| 4              | R/W        | 0x0         | SYS_MRL_SENSOR_CHGED<br>sys_mrl_sensor_chged[0] , MRL Sensor Changed.<br>Indicates that the state of MRL sensor has changed. There is a separate sys_mrl_sensor_chged input bit for each function in your controller configuration.                                                                                                                        |
| 3              | R/W        | 0x0         | SYS_PWR_FAULT_DET<br>sys_pwr_fault_det[0] , Power Fault Detected.<br>Indicates the power controller detected a power fault at this slot. There is a separate sys_pwr_fault_det input bit for each function in your controller configuration.                                                                                                               |
| 2              | R/W        | 0x0         | SYS_MRL_SENSOR_STATE<br>sys_mrl_sensor_state[0] , MRL Sensor State.<br>Indicates the state of the manually-operated retention latch (MRL) sensor:<br><ul style="list-style-type: none"> <li>▪ 0: MRL is closed</li> <li>▪ 1: MRL is open</li> </ul> There is a separate sys_mrl_sensor_state input bit for each function in your controller configuration. |
| 1              | R/W        | 0x0         | SYS_PRE_DET_STATE<br>sys_pre_det_state[0] , Presence Detect State.<br>Indicates whether or not a card is present in the slot:<br><ul style="list-style-type: none"> <li>▪ 0: Slot is empty</li> <li>▪ 1: Card is present in the slot</li> </ul> There is a separate sys_pre_det_state input bit for each function in your controller configuration.        |
|                | R/W        | 0x0         | SYS_ATTEN_BUTTON_PRESSED                                                                                                                                                                                                                                                                                                                                   |

| Offset: 0x0A00 |            |             | Register Name: SII_ELEC                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                   |
| 0              |            |             | sys_atten_button_pressed[0] , Attention Button Pressed. Indicates that the system attention button was pressed, sets the Attention Button Pressed bit in the Slot Status Register. There is a separate sys_atten_button_pressed input bit for each function in your controller configuration. |

#### 8.12.5.30 0xB04 PCIE FRS READY Register (Default Value: 0x0000\_0000)

| Offset: 0xB04 |            |             | Register Name: FRS_READY                                                          |
|---------------|------------|-------------|-----------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                       |
| 31:5          | /          | /           | /                                                                                 |
| 4             | R/W        | 0x0         | APP_PF0_FRS_READY<br>app_pf_frs_ready[0]<br>Defers FRS messaging when set to '0'. |
| 3:0           | /          | /           | /                                                                                 |

#### 8.12.5.31 0xC00 PCIE LTSSM Enable Register (Default Value: 0x0000\_0040)

| Offset: 0xC00 |            |             | Register Name: PCIE_LTSSM_ENABLE                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 31            | R/W        | 0x0         | APP_DBI_RO_WR_DISABLE<br>app_dbi_ro_wr_disable<br>DBI Read-only Write Disable <ul style="list-style-type: none"> <li>▪ 0: MISC_CONTROL_1_OFF.DBI_RO_WR_EN register field is read-write.</li> <li>▪ 1: MISC_CONTROL_1_OFF.DBI_RO_WR_EN register field is forced to 0 and is read-only.</li> </ul>                                                                                                                                                                                |
| 30:1          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0             | R/W        | 0x0         | APP_LTSSM_ENABLE<br>Link Training Enable<br>0: Disable link training<br>1: Enable link training<br>Driven low by your application after cold, warm or hot reset to hold the LTSSM in the Detect state until your application is ready for the link training to begin. When your application has finished reprogramming the controller configuration registers using the DBI, it asserts app_ltssm_enable to allow the LTSSM to continue link establishment. Can also be used to |

| Offset: 0x0C00 |            |             | Register Name: PCIE_LTSSM_ENABLE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                |            |             | <p>delay hot resetting of the controller until you have read out any register status.</p> <p>Cold Reset:</p> <ul style="list-style-type: none"> <li>▪ Optionally hold LTSSM and delay link training, so that you can reprogram some registers through DBI.</li> <li>▪ Set app_ltssm_enable =0 before your application de-asserts Power-On Reset (power_up_rst_n). Best way is to set app_ltssm_enable =0 at power-up or at assertion of core_RST_N.</li> <li>▪ Wait for de-assertion of core_RST_N, sticky_RST_N, and non_sticky_RST_N.</li> <li>▪ Write any register through DBI.</li> <li>▪ Set app_ltssm_enable =1.</li> <li>▪ Link training starts.</li> </ul> <p>Hot Reset (Link Down Reset) :</p> <ul style="list-style-type: none"> <li>▪ Optionally delay reset of the controller, so that you can read some registers through DBI.</li> <li>▪ Set app_ltssm_enable =0 immediately (combinatorially) upon falling edge of smlh_req_RST_not.</li> <li>▪ Keep app_ltssm_enable =0 until bridge finishes "flushing mode".</li> <li>▪ Read any register through DBI.</li> <li>▪ Set app_ltssm_enable =1.</li> <li>▪ Reset of controller begins (sticky_RST is not asserted).</li> <li>▪ Optionally hold LTSSM and delay link training, so that you can reprogram some registers through DBI.</li> <li>▪ Set app_ltssm_enable =0 immediately (combinatorially) upon falling edge of core_RST_N.</li> <li>▪ Write any register through DBI.</li> <li>▪ Set app_ltssm_enable =1.</li> <li>▪ Link training starts.</li> <li>▪ <b>Note: For Hot Reset, you can do both or either of the above (delay reset and/or delay link training). If you do both, you must do in order presented.</b></li> <li>▪ <b>Note: You must only de-assert this signal using one of the recommended timings described in the "Reset Requirements" section in the Architecture chapter of the Databook</b></li> </ul> <p>To do otherwise (that is, de-assert it outside of the Detect LTSSM state) causes the controller to be reset</p> |

| Offset: 0x0C00 |            |             | Register Name: PCIE_LTSSM_ENABLE                                                                                                                             |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                  |
|                |            |             | and the LTSSM moves immediately back to the Detect state. This transition is outside of the PCIe Specification and it might cause a PIPE protocol violation. |

#### 8.12.5.32 0x0E00 PCIE SII Interrupt Mask Register0 (Default Value: 0x0000\_0000)

| Offset: 0x0E00 |            |             | Register Name: SII_INT_MASK_0                         |
|----------------|------------|-------------|-------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                           |
| 31:30          | /          | /           | /                                                     |
| 29             | R/W        | 0x0         | RADM_MSG_LTR_EN_MASK<br>0: Mask<br>1: Not Mask        |
| 28             | R/W        | 0x0         | DEASSERT_INTD_GRT_EN_MASK<br>0: Mask<br>1: Not Mask   |
| 27             | R/W        | 0x0         | DEASSERT_INTC_GRT_EN_MASK<br>0: Mask<br>1: Not Mask   |
| 26             | R/W        | 0x0         | DEASSERT_INTB_GRT_EN_MASK<br>0: Mask<br>1: Not Mask   |
| 25             | R/W        | 0x0         | DEASSERT_INTA_GRT_EN_MASK<br>0: Mask<br>1: Not Mask   |
| 24             | R/W        | 0x0         | ASSERT_INTD_GRT_EN_MASK<br>0: Mask<br>1: Not Mask     |
| 23             | R/W        | 0x0         | ASSERT_INTC_GRT_EN_MASK<br>0: Mask<br>1: Not Mask     |
| 22             | R/W        | 0x0         | ASSERT_INTB_GRT_EN_MASK<br>0: Mask<br>1: Not Mask     |
| 21             | R/W        | 0x0         | ASSERT_INTA_GRT_EN_MASK<br>0: Mask<br>1: Not Mask     |
| 20             | R/W        | 0x0         | CFG_LINK_EQ_REQ_INT_EN_MASK<br>0: Mask<br>1: Not Mask |

| Offset: 0x0E00 |            |             | Register Name: SII_INT_MASK_0                          |
|----------------|------------|-------------|--------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                            |
| 19             | R/W        | 0x0         | CFG_BW_MGT_MSİ_EN_MASK<br>0: Mask<br>1: Not Mask       |
| 18             | R/W        | 0x0         | CFG_BW_MGT_INT_EN_MASK<br>0: Mask<br>1: Not Mask       |
| 17             | R/W        | 0x0         | CFG_LINK_AUTO_BW_MSİ_EN_MASK<br>0: Mask<br>1: Not Mask |
| 16             | R/W        | 0x0         | CFG_LINK_AUTO_BW_INT_EN_MASK<br>0: Mask<br>1: Not Mask |
| 15             | R/W        | 0x0         | PF0_HP_MSİ_EN_MASK<br>0: Mask<br>1: Not Mask           |
| 14             | R/W        | 0x0         | PF0_HP_INT_EN_MASK<br>0: Mask<br>1: Not Mask           |
| 13             | R/W        | 0x0         | PF0_HP_PME_EN_MASK<br>0: Mask<br>1: Not Mask           |
| 12             | R/W        | 0x0         | RADM_INTD_DEASSERTED_EN_MASK<br>0: Mask<br>1: Not Mask |
| 11             | R/W        | 0x0         | RADM_INTC_DEASSERTED_EN_MASK<br>0: Mask<br>1: Not Mask |
| 10             | R/W        | 0x0         | RADM_INTB_DEASSERTED_EN_MASK<br>0: Mask<br>1: Not Mask |
| 9              | R/W        | 0x0         | RADM_INTA_DEASSERTED_EN_MASK<br>0: Mask<br>1: Not Mask |
| 8              | R/W        | 0x0         | RADM_INTD_ASSERTED_EN_MASK<br>0: Mask<br>1: Not Mask   |
| 7              | R/W        | 0x0         | RADM_INTC_ASSERTED_EN_MASK<br>0: Mask<br>1: Not Mask   |
| 6              | R/W        | 0x0         | RADM_INTB_ASSERTED_EN_MASK<br>0: Mask                  |

| Offset: 0x0E00 |            |             | Register Name: SII_INT_MASK_0                            |
|----------------|------------|-------------|----------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                              |
|                |            |             | 1: Not Mask                                              |
| 5              | R/W        | 0x0         | RADM_INTA_ASSERTED_EN_MASK<br>0: Mask<br>1: Not Mask     |
| 4              | R/W        | 0x0         | PF0_CFG_PME_MSI_EN_MASK<br>0: Mask<br>1: Not Mask        |
| 3              | R/W        | 0x0         | PF0_CFG_PME_INT_EN_MASK<br>0: Mask<br>1: Not Mask        |
| 2              | R/W        | 0x0         | PF0_CFG_AER_RC_ERR_MSI_MASK<br>0: Mask<br>1: Not Mask    |
| 1              | R/W        | 0x0         | PF0_CFG_AER_RC_ERR_INT_EN_MASK<br>0: Mask<br>1: Not Mask |
| 0              | R/W        | 0x0         | PF0_CFG_VPD_INT_EN_MASK<br>0: Mask<br>1: Not Mask        |

#### 8.12.5.33 0x0E04 PCIE SII Interrupt Mask Register1 (Default Value: 0x0000\_0000)

| Offset: 0x0E04 |            |             | Register Name: SII_INT_MASK_1                        |
|----------------|------------|-------------|------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                          |
| 31             | R/W        | 0x0         | PCIE_WAKE_N_CLR_EN_MASK<br>0: Mask<br>1: Not Mask    |
| 30             | R/W        | 0x0         | WAKE_CLR_EN_MASK<br>0: Mask<br>1: Not Mask           |
| 29             | R/W        | 0x0         | RADM_PM_TO_ACK_CLR_EN_MASK<br>0: Mask<br>1: Not Mask |
| 28             | R/W        | 0x0         | RADM_PM_PME_CLR_EN_MASK<br>0: Mask<br>1: Not Mask    |
| 27             | R/W        | 0x0         | RADM_FATAL_ERR_CLR_EN_MASK<br>0: Mask<br>1: Not Mask |
| 26             | R/W        | 0x0         | RADM_NONFATAL_ERR_CLR_EN_MASK                        |

| Offset: 0x0E04 |            |             | Register Name: SII_INT_MASK_1                              |
|----------------|------------|-------------|------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                |
|                |            |             | 0: Mask<br>1: Not Mask                                     |
| 25             | R/W        | 0x0         | RADM_CORRECTABLE_ERR_CLR_EN_MASK<br>0: Mask<br>1: Not Mask |
| 24             | R/W        | 0x0         | CFG_SYS_ERR_RC_CLR_EN_MASK<br>0: Mask<br>1: Not Mask       |
| 23:22          | /          | /           | /                                                          |
| 21             | R/W        | 0x0         | PF0_FRS_GRANT_EN_MASK<br>0: Mask<br>1: Not Mask            |
| 20             | R/W        | 0x0         | RADM_VENDOR_MSG_EN_MASK<br>0: Mask<br>1: Not Mask          |
| 19             | /          | /           | /                                                          |
| 18             | R/W        | 0x0         | PF0_FRSQ_MSI_EN_MASK<br>0: Mask<br>1: Not Mask             |
| 17             | R/W        | 0x0         | PF0_CFG_UP_DRS_TO_FRS_EN_MASK<br>0: Mask<br>1: Not Mask    |
| 16             | R/W        | 0x0         | PF0_CFG_DRS_MSI_EN_MASK<br>0: Mask<br>1: Not Mask          |
| 15:12          | /          | /           | /                                                          |
| 11             | R/W        | 0x0         | PCIE_PERI_AR_INT_EN_MASK<br>0: Mask<br>1: Not Mask         |
| 10             | R/W        | 0x0         | PCIE_PERI_AW_INT_EN_MASK<br>0: Mask<br>1: Not Mask         |
| 9              | R/W        | 0x0         | RADM_QOVERFLOW_1_EN_MASK<br>0: Mask<br>1: Not Mask         |
| 8              | R/W        | 0x0         | RADM_QOVERFLOW_0_EN_MASK<br>0: Mask<br>1: Not Mask         |
| 7:5            | /          | /           | /                                                          |
| 4              | R/W        | 0x0         | RTLH_RFC_UPD_0_EN_MASK<br>0: Mask                          |

| Offset: 0x0E04 |            |             | Register Name: SII_INT_MASK_1                                                  |
|----------------|------------|-------------|--------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                    |
|                |            |             | 1: Not Mask                                                                    |
| 3              | R/W        | 0x0         | LINK_REQ_RST_NOT_EN_MASK<br>0: Mask<br>1: Not Mask                             |
| 2              | /          | /           | /                                                                              |
| 1              | R/W        | 0x0         | RDLH_LINK_UP_INT_MASK<br>RDLH Link Up Interrupt Mask<br>0: Mask<br>1: Not Mask |
| 0              | R/W        | 0x0         | SMLH_LINK_UP_INT_MASK<br>SMLH Link Up Interrupt Mask<br>0: Mask<br>1: Not Mask |

#### 8.12.5.34 0x0E08 PCIE SII Interrupt Register0 (Default Value: 0x0000\_0000)

| Offset: 0x0E08 |            |             | Register Name: SII_INT_0                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                |
| 31:30          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                          |
| 29             | R/W1C      | 0x0         | RADM_MSG_LTR<br>One-clock-cycle pulse that indicates that the controller received an LTR message. The controller makes the message header available the radm_msg_payload output. It is also available the app_ltr_latency output. When RX_TLP > 1 and when two messages of the same type are received in the same clock cycle (back-to-back), then no separate indication is given for the second message. |
| 28             | R/W1C      | 0x0         | DEASSERT_INTD_GRT<br>The signal deassert_intd_grt is a one-clock-cycle pulse that indicates that the controller sent an Deassert_INTD Message to the upstream device.                                                                                                                                                                                                                                      |
| 27             | R/W1C      | 0x0         | DEASSERT_INTC_GRT<br>The signal deassert_intc_grt is a one-clock-cycle pulse that indicates that the controller sent an Deassert_INTC Message to the upstream device.                                                                                                                                                                                                                                      |
| 26             | R/W1C      | 0x0         | DEASSERT_INTB_GRT<br>The signal deassert_intb_grt is a one-clock-cycle pulse that indicates that the controller sent an Deassert_INTB Message to the upstream device.                                                                                                                                                                                                                                      |
| 25             | R/W1C      | 0x0         | DEASSERT_INTA_GRT                                                                                                                                                                                                                                                                                                                                                                                          |

| Offset: 0xE08 |            |             | Register Name: SII_INT_0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|               |            |             | The signal deassert_inta_grt is a one-clock-cycle pulse that indicates that the controller sent an Deassert_INTA Message to the upstream device.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 24            | R/W1C      | 0x0         | ASSERT_INTD_GRT<br>The signal assert_intd_grt is a one-clock-cycle pulse that indicates that the controller sent an Assert_INTD Message to the upstream device.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 23            | R/W1C      | 0x0         | ASSERT_INTC_GRT<br>The signal assert_intd_grt is a one-clock-cycle pulse that indicates that the controller sent an Assert_INTD Message to the upstream device.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 22            | R/W1C      | 0x0         | ASSERT_INTB_GRT<br>The signal assert_intb_grt is a one-clock-cycle pulse that indicates that the controller sent an Assert_INTB Message to the upstream device.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 21            | R/W1C      | 0x0         | ASSERT_INTA_GRT<br>The signal assert_inta_grt is a one-clock-cycle pulse that indicates that the controller sent an Assert_INTA Message to the upstream device.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 20            | R/W1C      | 0x0         | CFG_LINK_EQ_REQ_INT<br>Interrupt indicating to your application that the Link Equalization Request bit in the Link Status 2 Register has been set and the Link Equalization Request Interrupt Enable (Link Control 3 Register bit 1) is set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 19            | R/W1C      | 0x0         | CFG_BW_MGT_MSI<br>The controller sets this pin when following conditions are true: <ul style="list-style-type: none"><li>▪ MSI or MSI-X is enabled.</li><li>▪ The Link Bandwidth Management Status register (Link Control Status register bit 14) is updated<ul style="list-style-type: none"><li>▪ The Link Bandwidth Management Interrupt Enable (Link Control register bit 10) is set.</li></ul></li></ul> reuse-pragma beginAttr Description This pin is set as a notification when the Link Bandwidth Management Status register (Link Status register bit 14) is updated and the Link Bandwidth Management Interrupt Enable (Link Control register bit 10) is set and in addition the msi or msix aare enabled . This bit is not applicable to, and is reserved, for endpoint devices and upstream ports of Switches. For upstream port: Reserved. <ct:CX_IS_EP>Reserved. |

| Offset: 0x0E08 |            |             | Register Name: SII_INT_0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 18             | R/W1C      | 0x0         | <p>CFG_BW_MGT_INT</p> <p>The controller asserts cfg_bw_mgt_int when all of the following conditions are true:</p> <ul style="list-style-type: none"> <li>▪ The INTx Assertion Disable bit in the Command register is 0, and</li> <li>▪ The Bandwidth Management Interrupt Enable bit in the Link Control register is set to 1, and</li> <li>▪ The Bandwidth Management Interrupt Status bit in the Link Status register is set to 1.</li> </ul> <p>The cfg_bw_mgt_msi output is a pulse signal (only asserted for one clock cycle); but cfg_bw_mgt_int is a level signal.</p> <p>For upstream port: Reserved.</p>                                              |
| 17             | R/W1C      | 0x0         | <p>CFG_LINK_AUTO_BW_MSI</p> <p>The controller sets this pin when following conditions are true:</p> <ul style="list-style-type: none"> <li>▪ MSI or MSI-X is enabled.</li> <li>▪ The Link Autonomous Bandwidth Status register (Link Status register bit 15) is updated.</li> <li>▪ The Link Autonomous Bandwidth Interrupt Enable (Link Control register bit 11) is set.</li> </ul> <p>The controller does not check if the associated MSI vector (asserted cfg_PCIE_cap_int_msg_num) is unmasked. It is up to the application to check whether the vector is masked or unmasked.</p> <p>For upstream port: Reserved.</p> <p>&lt;ct:CX_IS_EP&gt;Reserved.</p> |
| 16             | R/W1C      | 0x0         | <p>CFG_LINK_AUTO_BW_INT</p> <p>The controller asserts cfg_link_auto_bw_int when all of the following conditions are true:</p> <ul style="list-style-type: none"> <li>▪ The INTx assertion disable bit in the Command register is 0, and</li> <li>▪ The Link Autonomous Bandwidth Interrupt Enable bit in the Link Control register is set to 1, and</li> <li>▪ The Link Autonomous Bandwidth Interrupt Status bit in the Link Status register is set to 1.</li> </ul> <p>The cfg_link_auto_bw_msi output is a pulse signal (only asserted for one clock cycle); but cfg_link_auto_bw_int is a level signal.</p> <p>For upstream port: Reserved.</p>            |

| Offset: 0xE08 |            |             | Register Name: SII_INT_0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 15            | R/W1C      | 0x0         | <p>PF0_HP_MSI</p> <p>The controller asserts hp_msi (as a one-cycle pulse) when the logical AND of the following conditions transitions from false to true:</p> <ul style="list-style-type: none"> <li>▪ MSI or MSI-X is enabled.</li> <li>▪ Hot-Plug interrupts are enabled in the Slot Control register.</li> <li>▪ Any bit in the Slot Status register transitions from 0 to 1 and the associated event notification is enabled in the Slot Control register. There is one bit of hp_int for each configured function. The controller pulses the hp_msi output only when any of the hot plug status bits change from 0 to 1 (as is hp_pme).</li> </ul>                                                                                                                                                                                                                                      |
| 14            | R/W1C      | 0x0         | <p>PF0_HP_INT</p> <p>The controller asserts hp_int when all of the following conditions are true:</p> <ul style="list-style-type: none"> <li>▪ The INTx Assertion Disable bit in the Command register is 0.</li> <li>▪ Hot-Plug interrupts are enabled in the Slot Control register.</li> <li>▪ Any bit in the Slot Status register is equal to 1, and the associated event notification is enabled in the Slot Control register. There is one bit of hp_int for each configured function. hp_int[0]</li> </ul>                                                                                                                                                                                                                                                                                                                                                                               |
| 13            | R/W1C      | 0x0         | <p>PF0_HP_PME</p> <p>The controller asserts hp_pme when all of the following conditions are true:</p> <ul style="list-style-type: none"> <li>▪ The PME Enable bit in the Power Management Control and Status register is set to 1.</li> <li>▪ Any bit in the Slot Status register transitions from 0 to 1 and the associated event notification is enabled in the Slot Control register.</li> </ul> <p>The controller does not check if the PM state is D1, D2, or D3hot. It is up to your application to check the value pm_dstate to make sure the device is in D1, D2, or D3hot. There is one bit of hp_pme for each configured function. The controller pulses the hp_pme output only when any hot plug status bit changes from 0 to 1 (as is hp_msi). hp_int stays asserted as long as the status bit is set. In addition, it asserts hp_pme only if PME is enabled, but it does not</p> |

| Offset: 0xE08 |            |             | Register Name: SII_INT_0                                                                                                                                                                                                                                                                                                                                      |
|---------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                   |
|               |            |             | matter if hot-plug interrupts are enabled.                                                                                                                                                                                                                                                                                                                    |
| 12            | R/W1C      | 0x0         | RADM_INTD_DEASSERTED<br>One-clock-cycle pulse that indicates that the controller received a Deassert_INTD Message from the downstream device.                                                                                                                                                                                                                 |
| 11            | R/W1C      | 0x0         | RADM_INTC_DEASSERTED<br>One-clock-cycle pulse that indicates that the controller received a Deassert_INTC Message from the downstream device.                                                                                                                                                                                                                 |
| 10            | R/W1C      | 0x0         | RADM_INTB_DEASSERTED<br>One-clock-cycle pulse that indicates that the controller received a Deassert_INTB Message from the downstream device.                                                                                                                                                                                                                 |
| 9             | R/W1C      | 0x0         | RADM_INTA_DEASSERTED<br>One-clock-cycle pulse that indicates that the controller received a Deassert_INTA Message from the downstream device.                                                                                                                                                                                                                 |
| 8             | R/W1C      | 0x0         | RADM_INTD_ASSERTED<br>One-clock-cycle pulse that indicates that the controller received an Assert_INTD Message from the downstream device.                                                                                                                                                                                                                    |
| 7             | R/W1C      | 0x0         | RADM_INTC_ASSERTED<br>One-clock-cycle pulse that indicates that the controller received an Assert_INTC Message from the downstream device.                                                                                                                                                                                                                    |
| 6             | R/W1C      | 0x0         | RADM_INTB_ASSERTED<br>One-clock-cycle pulse that indicates that the controller received an Assert_INTB Message from the downstream device.                                                                                                                                                                                                                    |
| 5             | R/W1C      | 0x0         | RADM_INTA_ASSERTED<br>One-clock-cycle pulse that indicates that the controller received an Assert_INTA Message from the downstream device.                                                                                                                                                                                                                    |
| 4             | R/W1C      | 0x0         | PF0_CFG_PME_MSI<br>The controller asserts cfg_pme_msi (as a one-cycle pulse) when all of the following conditions are true: <ul style="list-style-type: none"><li>▪ MSI or MSI-X is enabled.</li><li>▪ The PME Interrupt Enable bit in the Root Control register is set to 1.</li><li>▪ The PME Status bit in the Root Status register is set to 1.</li></ul> |

| Offset: 0xE08 |            |             | Register Name: SII_INT_0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|---------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|               |            |             | <p>The controller does not check if the associated MSI vector (asserted <code>cfg_PCIE_cap_int_msg_num</code>) is unmasked. It is up to the application to check whether the vector is masked or unmasked.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 3             | R/W1C      | 0x0         | <p><b>PF0_CFG_PME_INT</b><br/> The controller asserts <code>cfg_pme_int</code> when all of the following conditions are true:</p> <ul style="list-style-type: none"> <li>▪ The INTx Assertion Disable bit in the Command register is 0.</li> <li>▪ The PME Interrupt Enable bit in the Root Control register is set to 1.</li> <li>▪ The PME Status bit in the Root Status register is set to 1.</li> </ul> <p>The <code>cfg_pme_msi</code> output is a pulse signal (only asserted for one clock cycle). But <code>cfg_pme_int</code> is a level signal; essentially an AND of the PME interrupt enable and receipt of the <code>pm_pme</code> message.</p>       |
| 2             | R/W1C      | 0x0         | <p><b>PF0_CFG_AER_RC_ERR_MSI</b><br/> The controller asserts <code>cfg_aer_rc_err_msi</code> for one clock cycle when all of the following conditions are true:</p> <ul style="list-style-type: none"> <li>▪ MSI or MSI-X is enabled.</li> <li>▪ A reported error condition causes a bit to be set in the Root Error Status register.</li> <li>▪ The associated error message reporting enable bit is set in the Root Error Command register.</li> </ul> <p>The controller does not check if the associated MSI vector (asserted <code>cfg_aer_int_msg_num</code>) is unmasked. It is up to the application to check whether the vector is masked or unmasked.</p> |
| 1             | R/W1C      | 0x0         | <p><b>PF0_CFG_AER_RC_ERR_INT</b><br/> Asserted when a reported error condition causes a bit to be set in the Root Error Status register and the associated error message reporting enable bit is set in the Root Error Command register.</p> <p><code>cfg_aer_rc_err_int</code> is set when the RC internally generates an error or when an error message is received by the RC. Because the RC itself generates it, this needs to be propagated up to the system software which would then need to read the error registers to see which error occurred.</p>                                                                                                      |

| Offset: 0x0E08 |            |             | Register Name: SII_INT_0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                |            |             | <p><b>Note:</b> This signal is used when MSI/MSI-X is NOT enabled; otherwise see <code>cfg_aer_rc_err_msi</code>.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 0              | R/W1C      | 0x0         | <p>PF0_CFG_VPD_INT<br/> This pin is set as a one cycle pulse to notify your application to read the VPD registers. The sequence of events for a VPD read cycle is:</p> <ul style="list-style-type: none"> <li>▪ The controller sends a request (single-cycle pulse of the <code>cfg_vpd_int</code> signal) to your application to read or write vital product data.</li> <li>▪ Your application reads the VPD Control and Capabilities register.</li> <li>▪ The VPD Flag (bit 31) is set to '0' indicating a read request. Your application fetches four bytes of data from the VPD Address location and transfers this to the VPD Data register.</li> <li>▪ Your application sets the VPD Flag bit to '1' indicating the request is complete.</li> </ul> <p>The sequence of events for a VPD write cycle is:</p> <ul style="list-style-type: none"> <li>▪ The controller sends a request (single-cycle pulse of the <code>cfg_vpd_int</code> signal) to your application to read or write vital product data.</li> <li>▪ Your application reads the VPD Control and Capabilities register.</li> <li>▪ The VPD Flag (bit 31) is set to '1' indicating a write request. Your application reads the VPD Data register and transfers this to the location specified by the VPD Address register.</li> <li>▪ Your application sets the VPD Flag bit to '0' indicating the request is complete.</li> </ul> |

#### 8.12.5.35 0x0E0C PCIE SII Interrupt Register1 (Default Value: 0x0000\_0000)

| Offset: 0x0E0C |            |             | Register Name: SII_INT_1                                                                                                                                                                                               |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                            |
| 31             | R/W1C      | 0x0         | PCIE_WAKE_N<br>remote wake (USP)                                                                                                                                                                                       |
| 30             | R/W1C      | 0x0         | WAKE<br>local wake. Wake up from power management unit.<br>The controller generates wake to request the system to restore power and clock when a wakeup event has been detected such as <code>apps_pm_xmt_pme</code> , |

| Offset: 0xE0C |            |             | Register Name: SII_INT_1                                                                                                                                                                                                                                                                                                                                                               |
|---------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                            |
|               |            |             | apps_pm_vf_xmt_pme, or outband_pwrup_cmd.<br>The wake signal is an active high signal and its rising edge should be detected to drive the WAKE# the connector. Assertion of wake could be for a single clock cycle or multiple clock cycles. Not used in RC mode.                                                                                                                      |
| 29            | R/W1C      | 0x0         | RADM_PM_TO_ACK<br>One-clock-cycle pulse that indicates that the controller received a PME_TO_Ack message.<br>Upstream port: Reserved.                                                                                                                                                                                                                                                  |
| 28            | R/W1C      | 0x0         | RADM_PM_PME<br>One-clock-cycle pulse that indicates that the controller received a PM_PME message.                                                                                                                                                                                                                                                                                     |
| 27            | R/W1C      | 0x0         | RADM_FATAL_ERR<br>One-clock-cycle pulse that indicates that the controller received an ERR_FATAL message.                                                                                                                                                                                                                                                                              |
| 26            | R/W1C      | 0x0         | RADM_NONFATAL_ERR<br>One-clock-cycle pulse that indicates that the controller received an ERR_NONFATAL message.                                                                                                                                                                                                                                                                        |
| 25            | R/W1C      | 0x0         | RADM_CORRECTABLE_ERR<br>One-clock-cycle pulse that indicates that the controller received an ERR_COR message. The controller makes the message header available the radm_msg_payload output.                                                                                                                                                                                           |
| 24            | R/W1C      | 0x0         | PF0_CFG_SYS_ERR_RC<br>System error detected. A one-clock-cycle pulse that indicates if any device in the hierarchy reports any of the following errors and the associated enable bit is set in the Root Control register: ERR_COR, ERR_FATAL, ERR_NONFATAL. Also asserted when an internal error is detected. There is one bit of cfg_sys_err_rc assigned to each configured function. |
| 23:22         | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                      |
| 21            | R/W1C      | 0x0         | PF0_FRS_GRANT<br>Indicator of when an FRS message for this function has been scheduled for transmission.                                                                                                                                                                                                                                                                               |
| 20            | R/W1C      | 0x0         | RADM_VENDOR_MSG<br>One-cycle pulse that indicates the controller received a vendor-defined message. The controller makes the message header available the radm_msg_payload                                                                                                                                                                                                             |

| Offset: 0xE0C |            |             | Register Name: SII_INT_1                                                                                                                                                                                                                                                                                                                               |
|---------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                            |
|               |            |             | output. When FX_TLP > 1 and when two messages of the same type are received in the same clock cycle (back-to-back), then both bits are asserted.                                                                                                                                                                                                       |
| 19            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                      |
| 18            | R/W1C      | 0x0         | PF0_FRSQ_MSI<br>FRSQ Interrupt Pulse. The RC asserts this output when it receives an FRQ message or when the FRS queue overflows.                                                                                                                                                                                                                      |
| 17            | R/W1C      | 0x0         | PF0_CFG_UP_DRS_TO_FRS<br>DRS to FRS Pulse. The PCIe controller asserts the cfg_up_drs_to_frsoutput and sends an FRS message with the reason code set to 'DRS Message Received' when: <ul style="list-style-type: none"><li>▪ It receives a DRS message, and</li><li>▪ PCIE_CAP_DRS_SIGNALING_CONTROL in INK_CONTROL_LINK_STATUS_REG is 2'b10</li></ul> |
| 16            | R/W1C      | 0x0         | PF0_CFG_DRS_MSI<br>DRS Message Received Interrupt Pulse. The PCIe controller asserts the cfg_drs_msi output when all of the following are true: <ul style="list-style-type: none"><li>▪ It receives a DRS message</li><li>▪ PCIE_CAP_DRS_SIGNALING_CONTROL in INK_CON_TROL_LINK_STATUS_REG is 2'b01</li><li>▪ MSI or MSI-X is enabled</li></ul>        |
| 15:12         | /          | /           | /                                                                                                                                                                                                                                                                                                                                                      |
| 11            | R/W1C      | 0x0         | PCIE_PERI_AR_INT<br>PCIe read peripherals space(0-1G) int                                                                                                                                                                                                                                                                                              |
| 10            | R/W1C      | 0x0         | PCIE_PERI_AW_INT<br>PCIe write peripherals space(0-1G) int                                                                                                                                                                                                                                                                                             |
| 9             | R/W1C      | 0x0         | RADM_QOVERFLOW_1<br>Pulse indicating that one or more of the P/NP/CPL receive queues have overflowed. There is a 1-bit indication for each configured virtual channel. You can connect this output to your internal error reporting mechanism.                                                                                                         |
| 8             | R/W1C      | 0x0         | RADM_QOVERFLOW_0<br>Pulse indicating that one or more of the P/NP/CPL receive queues have overflowed. There is a 1-bit indication for each configured virtual channel. You can connect this output to your internal error reporting mechanism.                                                                                                         |

| Offset: 0x0E0C |            |             | Register Name: SII_INT_1                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 7:5            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 4              | R/W1C      | 0x0         | RTLH_RFC_UPD<br>Indicates that the controller received a flow control update DLLP. Used for applications that implement flow Control outside the controller.                                                                                                                                                                                                                                                                                                |
| 3              | R/W1C      | 0x0         | LINK_REQ_RST_NOT<br>Reset request because the link has gone down or the controller received a hot-reset request. A low level indicates that the controller is requesting external logic to reset the controller because the PHY link is down. When the AXI bridge module is enabled the link reset request is delayed until all pending AXI transfers have completed. When the AXI Bridge module is not enabled the link reset request is sent immediately. |
| 2              | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 1              | R/W1C      | 0x0         | RDLH_LINK_UP<br>Data link layer up/down indicator: This status from the flow control initialization state machine indicates that flow control has been initiated and the Data link layer is ready to transmit and receive packets. For multi-VC designs, this signal indicates status for VC0 only. <ul style="list-style-type: none"><li>▪ 1: Link is up</li><li>▪ 0: Link is down</li></ul>                                                               |
| 0              | R/W1C      | 0x0         | SMLH_LINK_UP<br>PHY Link up/down indicator: <ul style="list-style-type: none"><li>▪ 1: Link is up</li><li>▪ 0: Link is down</li></ul>                                                                                                                                                                                                                                                                                                                       |

#### 8.12.5.36 0x1000 PCIE SII APP PM UNLOCK Register (Default Value: 0x0000\_0000)

| Offset: 0x1000 |            |             | Register Name: SII_APP_PM_UNLOCK                                                                                                                                                                                                           |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                |
| 31:2           | /          | /           | /                                                                                                                                                                                                                                          |
| 1              | R/W        | 0x0         | APP_UNLOCK_MSG<br>app_unlock_msg_ahb<br>Request from your application to generate an Unlock message. You must assert this signal for one clock cycle. The controller does not return an acknowledgment or grant signal. You must not pulse |

| Offset: 0x1000 |            |             | Register Name: SII_APP_PM_UNLOCK                                                                                                                                                                                                                                                                                                |  |  |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                     |  |  |
|                |            |             | the same signal again, until the previous message has been transmitted.                                                                                                                                                                                                                                                         |  |  |
| 0              | R/W        | 0x0         | APP_PM_XMT_TURNOFF<br>apps_pm_xmt_turnoff_ahb<br>Request from your application to generate a PM_Turn_Off message. You must assert this signal for one clock cycle. The controller does not return an acknowledgment or grant signal. You must not pulse the same signal again, until the previous message has been transmitted. |  |  |

#### 8.12.5.37 0x1100 PCIE SII Power Manage Register0 (Default Value: 0x0000\_0000)

| Offset: 0x1100 |            |             | Register Name: SII_APP_PM_0                                                                                                                                                                                                         |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                         |
| 31:13          | /          | /           | /                                                                                                                                                                                                                                   |
| 12             | R/W        | 0x0         | APP_L1SUB_DISABLE<br>The application can set this input to 1'b1 to prevent entry to L1 Sub-states. This pin is used to gate the L1 sub-state enable bits from the L1 PM Substates Control 1 Register.                               |
| 11             | R/W        | 0x0         | APP_L1_PWR_OFF_EN<br>Application permits to gate power to parts of the controller in L1 state                                                                                                                                       |
| 10             | R/W        | 0x0         | ACK_EN_VMAIN<br>Acknowledge from power switch responsible for autonomous power-gating in L1.2.<br>This signal is synchronized using aux_clk and can be driven/supplied asynchronously to the controller in certain low-power modes. |
| 9              | R/W        | 0x0         | TEST_BYPASS_LP<br>Test mode override of isolation enable                                                                                                                                                                            |
| 8              | R/W        | 0x0         | APP_CLK_PM_EN<br>Clock PM feature enabled by application. Used to inhibit the programming of the Clock PM in Link Control Register.                                                                                                 |
| 7              | R/W        | 0x0         | CLKREQ_IN_N<br>Status of the CLKREQ# bidirectional CMOS board-level signal. Used by the controller to determine when to enter and exit L1 Substates when using the CLKREQ#-based mechanism.                                         |

| Offset: 0x1100 |            |             | Register Name: SII_APP_PM_0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 6              | R/W        | 0x0         | <p>APP_XFER_PENDING</p> <p>Indicates that your application has transfers pending and prevents the controller from entering L1. This is a level signal used to inform the controller about the state of external queues and pipeline stages that contain transactions to be transmitted by the controller. The controller uses this information to determine when to enter/exit L1. When this signal is asserted, it indicates that there are transactions outside the controller that the controller needs to transmit. When de-asserted, it indicates that there are no transactions outside the controller. The controller responds to an assertion on this signal as follows:</p> <ul style="list-style-type: none"> <li>▪ Upstream Ports: Prevents generation of requests to enter L1. Triggers exit if already in L1.</li> <li>▪ Downstream Ports: Triggers exit if already in L1.</li> </ul> <p>You can instruct the controller to exit L1 by asserting either or both of app_xfer_pending and app_req_exit_l1. The controller only samples app_req_exit_l1 when the controller is already in the L1 state.</p> |
| 5              | R/W        | 0x0         | <p>APP_REQ_EXIT_L1</p> <p>Application request to Exit L1. Request from your application to exit L1. It is only effective when L1 is enabled.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 4              | R/W        | 0x0         | <p>APP_READY_ENTR_L23</p> <p>Application Ready to Enter L23. Indication from your application that it is ready to enter the L23 state. The app_ready_entr_l23 signal is provided for applications that must control L23 entry (in case certain tasks must be performed before going into L23). The controller delays sending PM_Enter_L23 (in response to PM_Turn_Off) until this signal becomes active. When this signal has been asserted by the application, it must be kept asserted until L2 entry has completed. Hardwire to 1 for applications that do not require this feature.</p> <p><b>Note:</b> The controller ignores this input in RC mode.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 3              | R/W        | 0x0         | <p>APP_REQ_ENTR_L1_AHB</p> <p>Application request to Enter L1 ASPM state. The</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

| Offset: 0x1100 |            |             | Register Name: SII_APP_PM_0                                                                                                                                                                                                                                                                                                                     |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                     |
|                |            |             | app_req_entr_l1 signal is for use by applications that need to control L1 entry instead of using the L1 entry timer as defined in the PCI Express Specification. It is only effective when L1 is enabled. The controller latches this request when in L0 or L0s; to be acted upon later.<br>Note: The controller ignores this input in RC mode. |
| 2              | R/W        | 0x0         | SYS_AUX_PWR_DET<br>Auxiliary Power Detected. Used to report to the host software that auxiliary power (Vaux) is present.                                                                                                                                                                                                                        |
| 1:0            | /          | /           | /                                                                                                                                                                                                                                                                                                                                               |



## 8.13 Two Wire Interface (TWI)

### 8.13.1 Overview

The Two Wire Interface (TWI) provides an interface between a CPU and any TWI-bus-compatible device that connects via the TWI bus. The TWI is designed to be compatible with the standard I2C bus protocol. The communication of the TWI is carried out by a byte-wise mode based on interrupt polled handshaking. Each device on the TWI bus is recognized by a unique address and can operate as either transmitter or receiver, a device connected to the TWI bus can be considered as master or slave when performing data transfers. Note that a master device is a device that initiates a data transfer on the bus and generates the clock signals to permit the transfer. During this transfer, any device addressed by this master is considered a slave.

The TWI has the following features:

- Up to 9 TWI controllers
  - 6 TWI controllers in CPUX domain: TWI0, TWI1, TWI2, TWI3, TWI4, and TWI5
  - 3 TWI controllers in CPUS domain: S\_TWI0, S\_TWI1, and S\_TWI2
- Compliant with I2C bus standard
- 7-bit and 10-bit device addressing modes
- Standard mode (up to 100 Kbit/s) and fast mode (up to 400 Kbit/s)
- Supports general call and start byte
- Master mode supports the following:
  - Bus arbitration in the case of multiple master devices
  - Clock synchronization and bit and byte waiting
  - Packet transmission and DMA
- Slave mode supports Interrupt on address detection

### 8.13.2 Block Diagram

the following figure shows the block diagram of TWI.

**Figure 8-46 TWI Block Diagram**



TWI contains the following sub-blocks:

**Table 8-35 TWI Sub-blocks**

| Sub-block | Description                                                                     |
|-----------|---------------------------------------------------------------------------------|
| RESET     | Module reset signal                                                             |
| INT       | Module output interrupt signal                                                  |
| CFG_REG   | Module configuration register in TWI                                            |
| PE        | Packet encoding/decoding                                                        |
| CCU       | Module clock controller unit                                                    |
| SEND_FIFO | The register address bytes and the written data bytes are buffered in SEND_FIFO |
| RECV_FIFO | The read data bytes are buffered in RECV_FIFO                                   |

The controller includes TWI engine and TWI driver. Each time the TWI engine sends a START signal, a STOP signal, or a BYTE data, or a corresponding ACK, the TWI engine will generate an interrupt, and wait for the CPU to process and clear the interrupt before the next START, STOP, or BYTE, ACK transmission can be performed. Therefore, when a device communication is completed, many interrupts will be generated, and the CPU needs to wait for the previous interrupt before it can configure the next one. The TWI driver defines each communication with the device as a packet transmission. The CPU can directly configure the slave address, register address and data transmission for one or more package transmissions without waiting for interruption, then start the TWI driver, and the TWI driver can control the TWI engine to complete a pre-configured communication, and report an interrupt to the CPU after completion.

### 8.13.3 Functional Description

#### 8.13.3.1 External Signals

The following table describes the external signals of the TWI. The TWIn-SCK and TWIn-SDA are bidirectional I/O, when the TWI is configured as a master device, the TWIn-SCK is an output pin; when the TWI is configurable as a slave device, the TWIn-SCK is an input pin. When using TWI, the corresponding PADs are selected as TWI function via section 8.5 GPIO.

**Table 8-36 TWI External Signals**

| Signal Name | Description                | Type |
|-------------|----------------------------|------|
| TWI0-SCK    | TWI0 Serial Clock Signal   | I/O  |
| TWI0-SDA    | TWI0 Serial Data Signal    | I/O  |
| TWI1-SCK    | TWI1 Serial Clock Signal   | I/O  |
| TWI1-SDA    | TWI1 Serial Data Signal    | I/O  |
| TWI2-SCK    | TWI2 Serial Clock Signal   | I/O  |
| TWI2-SDA    | TWI2 Serial Data Signal    | I/O  |
| TWI3-SCK    | TWI3 Serial Clock Signal   | I/O  |
| TWI3-SDA    | TWI3 Serial Data Signal    | I/O  |
| TWI4-SCK    | TWI4 Serial Clock Signal   | I/O  |
| TWI4-SDA    | TWI4 Serial Data Signal    | I/O  |
| TWI5-SCK    | TWI5 Serial Clock Signal   | I/O  |
| TWI5-SDA    | TWI5 Serial Data Signal    | I/O  |
| S-TWI0-SCK  | S-TWI0 Serial Clock Signal | I/O  |
| S-TWI0-SDA  | S-TWI0 Serial Data Signal  | I/O  |
| S-TWI1-SCK  | S-TWI1 Serial Clock Signal | I/O  |
| S-TWI1-SDA  | S-TWI1 Serial Data Signal  | I/O  |
| S-TWI2-SCK  | S-TWI1 Serial Clock Signal | I/O  |
| S-TWI2-SDA  | S-TWI1 Serial Data Signal  | I/O  |

#### 8.13.3.2 Clock Sources

Each TWI controller has an input clock source. The following table describes the clock sources for TWI. After selecting a proper clock, users must open the gating of TWI and release the corresponding reset bit.

For more details on the clock setting, configuration, and gating information, see section 2.5 Clock Controller Unit (CCU) and section 2.11 Power Reset Clock Management (PRCM).

**Table 8-37 TWI Clock Sources**

| Clock Sources | Description                                             | Module |
|---------------|---------------------------------------------------------|--------|
| APB1 Bus      | TWI clock source. Refer to CCU for details on APB1.     | CCU    |
| APBS1 Bus     | S_TWI clock source. Refer to PRCM for details on APBS1. | PRCM   |

### 8.13.3.3 Write/Read Timing in Standard and Extended Addressing Mode

This section is the 7-bit/10-bit addressing mode of the entire TWI protocol to read and write device registers. It can be achieved by directly using the TWI engine or using the TWI driver to control the TWI engine.

The following figure describes the write timing in 7-bit standard addressing mode.

**Figure 8-47 Write Timing in 7-bit Standard Addressing Mode**

Slave addr = 7-bit , register addr = 8-bit, data = 8-bit



Slave addr = 7-bit , register addr = 8-bit, data = n-byte



data transferred(n-byte + acknowledge)

from master to slave

S: START condition

A: acknowledge(SDA LOW)

from slave to master

P: STOP condition

$\bar{A}$ : not acknowledge(SDA HIGH)

The following figure describes the read timing in 7-bit standard address mode.

**Figure 8-48 Read Timing in 7-bit Standard Addressing Mode**

Slave addr = 7-bit , register addr = 8-bit, data = 8-bit



Slave addr = 7-bit , register addr = 8-bit, data = n-byte



data transferred(n-byte + acknowledge)

from master to slave

S: START condition

A: acknowledge(SDA LOW)

Sr: RE-START condition

from slave to master

P: STOP condition

$\bar{A}$ : not acknowledge(SDA HIGH)

The following figure describes the write timing in 10-bit extended address mode.

**Figure 8-49 Write Timing in 10-bit Extended Addressing Mode**

Slave addr = 10-bit , register addr = 8-bit, data = 8-bit



Slave addr = 10-bit , register addr = 8-bit, data = n-byte



data transferred(n-byte + acknowledge)

from master to slave

S: START condition

A: acknowledge(SDA LOW)

from slave to master

P: STOP condition

$\bar{A}$ : not acknowledge(SDA HIGH)

The following figure describes the read timing in 10-bit extended address mode.

**Figure 8-50 Read Timing in 10-bit Extended Addressing Mode**

Slave addr = 10-bit , register addr = 8-bit, data = 8-bit



Slave addr = 10-bit , register addr = 8-bit, data = n-byte



data transferred(n-byte + acknowledge)

from master to slave

S<sub>t</sub>: START condition

A<sub>t</sub>: acknowledge(SDA LOW)

from slave to master

S<sub>r</sub>: RE-START condition

P: STOP condition

$\bar{A}$ : not acknowledge(SDA HIGH)

### 8.13.3.4 Write/Read Packet Transmission of TWI Driver

The TWI driver is only supported for master mode. When the TWI works in master mode, the TWI driver drives the TWI engine for one or more packet transmission instead of the CPU host. Packet transmission is defined in the following figures. The register address bytes and the written data bytes are buffered in SEND\_FIFO, the read data bytes are buffered in RECV\_FIFO.

**Figure 8-51 TWI Driver Write Packet Transmission**



Figure 8-52 TWI Driver Read Packet Transmission



### 8.13.3.5 Master and Slave Mode of TWI Engine

In Master mode, the CPU host controls the TWI engine by writing command and data to its registers. The TWI engine transmits an interrupt to CPU when each time a byte transfer is done or a START/STOP command is detected. The CPU host can poll the status register if the interrupt mechanism is not disabled by the CPU host.

When the CPU host wants to start a bus transfer, it initiates a bus START to enter the master mode by setting [TWI\\_CNTR\[M\\_STA\]](#) to high. The TWI engine will assert the INT line and [TWI\\_CNTR\[INT\\_FLAG\]](#) to indicate a completion for the START command and each consequent byte transfer. At each interrupt, the CPU host needs to check the current state by the [TWI\\_STAT](#)

register. A transfer must conclude with the STOP command by setting [TWI\\_CNTR\[M\\_STP\]](#) to high.

In Slave mode, the TWI engine also constantly samples the bus and look for its own slave address during addressing cycles. Once a match is found, it is addressed, and the TWI engine interrupts the CPU host with the corresponding status. Upon request, the CPU host should read the status, read/write the [TWI\\_DATA](#) register, and set the [TWI\\_CNTR](#) register. After each byte transfer, a slave device always stops the operation of the remote master by holding the next low pulse on the SCL line until the CPU host responds to the status of the previous byte transfer or START command.

#### 8.13.3.6 Generation of Repeated Start

After the data transfer, if the master still requires the bus, it can signal another Start followed by another slave address without signaling a Stop.

#### 8.13.3.7 Programming State Diagram

Figure 8-53 shows the TWI programming state diagram. For the value between two states, see the [TWI\\_STAT](#) register in section 8.13.6.5.

M\_SEND\_S: master sends START signal;  
M\_SEND\_ADDR: master sends slave address;  
M\_SEND\_XADD: master sends slave extended address;  
M\_SEND\_SR: master repeated start;  
M\_SEND\_DATA: master sends data;  
M\_SEND\_P: master sends STOP signal;  
M\_RECV\_DATA: master receives data;  
ARB\_LOST: Arbitration lost;  
C\_IDLE: Idle.

Figure 8-53 TWI Programming State Diagram



#### 8.13.4 Programming Guidelines

The TWI controller operates in an 8-bit data format. The data on the TWI\_SDA line is always 8 bits long. At first, the TWI controller sends a start condition. When in the addressing formats of 7-bit, the TWI sends out an 8-bit message which includes 7 MSB slave address and 1 LSB read/write flag. The least significant of the slave address indicates the direction of transmission. When the TWI works in 10-bit slave address mode, the operation will be divided into two steps, for details on the operation, refer to register description in Section 8.13.6.1 and 8.13.6.2.

The following takes the TWI module in the CPUX domain as an example.

##### 8.13.4.1 Initialization for TWI Engine

To initialize the TWI engine, perform the following steps:

- Step 1** Configure corresponding GPIO multiplex function as TWI mode.
- Step 2** For TWIn, set [TWI\\_BGR\\_REG\[TWIn\\_GATING\]](#) in CCU module to 0 to close TWIn clock.
- Step 3** For TWIn, set [TWI\\_BGR\\_REG\[TWIn\\_RST\]](#) in CCU module to 0, then set to 1 to reset TWIn.
- Step 4** For TWIn, set [TWI\\_BGR\\_REG\[TWIn\\_GATING\]](#) in CCU module to 1 to open TWIn clock.
- Step 5** Configure [TWI\\_CCR\[CLK\\_M\]](#) and [TWI\\_CCR\[CLK\\_N\]](#) to get the needed rate (The clock source of TWI is from APB1).

- Step 6** Configure [TWI\\_CNTR\[BUS\\_EN\]](#) and [TWI\\_CNTR\[A\\_ACK\]](#), when using interrupt mode, set [TWI\\_CNTR\[INT\\_EN\]](#) to 1, and register the system interrupt through GIC module. In slave mode, configure [TWI\\_ADDR](#) and [TWI\\_XADDR](#) registers to finish TWI initialization configuration.

#### 8.13.4.2 Writing Data Operation for TWI Engine

To write data to the device, perform the following steps:

- Step 1** Clear [TWI\\_EFR](#) register, and configure [TWI\\_CNTR\[M\\_STA\]](#) to 1 to transmit the START signal.
- Step 2** After the START signal is transmitted, the first interrupt is triggered, then write device ID to [TWI\\_DATA](#) (For a 10-bit device ID, firstly write the first byte ID, secondly write the second byte ID in the next interrupt).
- Step 3** The Interrupt is triggered again after device ID transmission completes, write device data address to be read to [TWI\\_DATA](#) (For a 16-bit address, firstly write the first-byte address, secondly write the second-byte address).
- Step 4** Interrupt is triggered after data address transmission completes, write data to be transmitted to [TWI\\_DATA](#) (For consecutive write data operation, every byte transmission completion triggers interrupt, during interrupt write the next byte data to [TWI\\_DATA](#)).
- Step 5** After transmission completes, write [TWI\\_CNTR\[M\\_STP\]](#) to 1 to transmit the STOP signal and end this write-operation.

#### 8.13.4.3 Reading Data Operation for TWI Engine

To read data from the device, perform the following steps:

- Step 1** Clear [TWI\\_EFR](#) register, and set [TWI\\_CNTR\[A\\_ACK\]](#) to 1, and configure [TWI\\_CNTR\[M\\_STA\]](#) to 1 to transmit the START signal.
- Step 2** After the START signal is transmitted, the first interrupt is triggered, then write device ID to [TWI\\_DATA](#) (For a 10-bit device ID, firstly write the first-byte ID, secondly write the second-byte ID in the next interrupt).
- Step 3** The Interrupt is triggered again after device ID transmission completes, write device data address to be read to [TWI\\_DATA](#) (For a 16-bit address, firstly write the first-byte address, secondly write the second-byte address).
- Step 4** The Interrupt is triggered after data address transmission completes, write [TWI\\_CNTR\[M\\_STA\]](#) to 1 to transmit new START signal, and after interrupt triggers, write device ID to [TWI\\_DATA](#) to start read-operation.

**Step 5** After device address transmission completes, each receive completion will trigger an interrupt, in turn, read [TWI\\_DATA](#) to get data, when receiving the previous interrupt of the last byte data, clear [A\_ACK] to stop acknowledge signal of the last byte.

**Step 6** Write [TWI\\_CNTR\[M\\_STP\]](#) to 1 to transmit the STOP signal and end this read-operation.

#### 8.13.4.4 Initialization for TWI Driver

To initialize the TWI driver, perform the following steps:

**Step 1** Configure corresponding GPIO multiplex function as TWI mode.

**Step 2** For TWIn, set [TWI\\_BGR\\_REG\[TWIn\\_GATING\]](#) in CCU module to 0 to close TWIn clock.

**Step 3** For TWIn, set [TWI\\_BGR\\_REG\[TWIn\\_RST\]](#) in CCU module to 0, then set to 1 to reset TWIn.

**Step 4** For TWIn, set [TWI\\_BGR\\_REG\[TWIn\\_GATING\]](#) in CCU module to 1 to open TWIn clock.

**Step 5** Set [TWI\\_DRV\\_CTRL\[TWI\\_DRV\\_EN\]](#) to 1 to enable the TWI driver.

**Step 6** Configure [TWI\\_DRV\\_BUS\\_CTRL\[CLK\\_M\]](#) and [TWI\\_DRV\\_BUS\\_CTRL\[CLK\\_N\]](#) to get the needed rate (The clock source of TWI is from APB1).

**Step 7** Set [TWI\\_DRV\\_CTRL\[RESTART\\_MODE\]](#) to 0 and [\[READ\\_TRAN\\_MODE\]](#) to 1, set [TWI\\_DRV\\_INT\\_CTRL\[TRAN\\_COM\\_INT\\_EN\]](#) to 1.

**Step 8** When using DMA for data transmission, set [TWI\\_DRV\\_DMA\\_CFG\[DMA\\_RX\\_EN\]](#) and [TWI\\_DRV\\_DMA\\_CFG\[DMA\\_TX\\_EN\]](#) to 1, and configure [TWI\\_DRV\\_DMA\\_CFG\[RX\\_TRIG\]](#) and [TWI\\_DRV\\_DMA\\_CFG\[TX\\_TRIG\]](#) to set the thresholds of RXFIFO and TXFIFO.

#### 8.13.4.5 Writing Packet Transmission for TWI Driver

To write package to the device, perform the following steps:

**Step 1** Configure [TWI\\_DRV\\_SLV\[SLV\\_ID\]](#) to set the device ID, and configure [TWI\\_DRV\\_SLV\[CMD\]](#) to 0 to set the write operation.

**Step 2** Configure [TWI\\_DRV\\_FMT\[ADDR\\_BYT\]](#) according to the address width of the device register, and [TWI\\_DRV\\_FMT\[DATA\\_BYT\]](#) according to the written data count in a packet.

**Step 3** Configure [TWI\\_DRV\\_CFG\[PACKET\\_CNT\]](#) to set the written packet number.

**Step 4** Configure DMA channel, including TWI TXFIFO, device register address, and the written data.

**Step 5** Set [START\_TRAN] to 1 to start TWI Driver transmission.

**Step 6** When TWI driver transmission completes, the interrupt is triggered, it indicates that the write packet transmission ends.

#### 8.13.4.6 Reading Packet Transmission for TWI Driver

- Step 1** To read package from the device, perform the following steps:
- Step 2** Configure [TWI\\_DRV\\_SLV](#)[SLV\_ID] to set the device ID, and configure [TWI\\_DRV\\_SLV](#)[CMD] to 1 to set the read operation.
- Step 3** Configure [TWI\\_DRV\\_FMT](#)[ADDR\_BYT] according to the address width of the device register, and [TWI\\_DRV\\_FMT](#)[DATA\_BYT] according to the read data count in a packet.
- Step 4** Configure [TWI\\_DRV\\_CFG](#)[PACKET\_CNT] to set the read packet number.
- Step 5** Configure DMA channel, including TWI TXFIFO, TWI RXFIFO, device register address and the read data.
- Step 6** Set [START\_TRAN] to 1 to start TWI Driver transmission.
- Step 7** When TWI driver transmission completes, the interrupt is triggered, it indicates that the read packet transmission ends.

#### 8.13.5 Register List

| Module Name | Base Address | Comments                               |
|-------------|--------------|----------------------------------------|
| TWI0        | 0x0250 2000  |                                        |
| TWI1        | 0x0250 2400  | TWI1 register is the same with TWI0.   |
| TWI2        | 0x0250 2800  | TWI2 register is the same with TWI0.   |
| TWI3        | 0x0250 2C00  | TWI3 register is the same with TWI0.   |
| TWI4        | 0x0250 3000  | TWI4 register is the same with TWI0.   |
| TWI5        | 0x0250 3400  | TWI5 register is the same with TWI0.   |
| S_TWI0      | 0x0708 1400  | R-TWI0 register is the same with TWI0. |
| S_TWI1      | 0x0708 1800  | R-TWI1 register is the same with TWI0. |
| S_TWI2      | 0x0708 1C00  | R-TWI2 register is the same with TWI0. |

| Register Name | Offset | Description                         |
|---------------|--------|-------------------------------------|
| TWI_ADDR      | 0x0000 | TWI Slave Address Register          |
| TWI_XADDR     | 0x0004 | TWI Extended Slave Address Register |
| TWI_DATA      | 0x0008 | TWI Data Byte Register              |
| TWI_CNTR      | 0x000C | TWI Control Register                |
| TWI_STAT      | 0x0010 | TWI Status Register                 |
| TWI_CCR       | 0x0014 | TWI Clock Control Register          |
| TWI_SRST      | 0x0018 | TWI Software Reset Register         |
| TWI_EFR       | 0x001C | TWI Enhance Feature Register        |
| TWI_LCR       | 0x0020 | TWI Line Control Register           |
| TWI_DRV_CTRL  | 0x0200 | TWI_DRV Control Register            |

| Register Name         | Offset | Description                                 |
|-----------------------|--------|---------------------------------------------|
| TWI_DRV_CFG           | 0x0204 | TWI_DRV Transmission Configuration Register |
| TWI_DRV_SLV           | 0x0208 | TWI_DRV Slave ID Register                   |
| TWI_DRV_FMT           | 0x020C | TWI_DRV Packet Format Register              |
| TWI_DRV_BUS_CTRL      | 0x0210 | TWI_DRV Bus Control Register                |
| TWI_DRV_INT_CTRL      | 0x0214 | TWI_DRV Interrupt Control Register          |
| TWI_DRV_DMA_CFG       | 0x0218 | TWI_DRV DMA Configure Register              |
| TWI_DRV_FIFO_CON      | 0x021C | TWI_DRV FIFO Content Register               |
| TWI_DRV_SEND_FIFO_ACC | 0x0300 | TWI_DRV Send Data FIFO Access Register      |
| TWI_DRV_RECV_FIFO_ACC | 0x0304 | TWI_DRV Receive Data FIFO Access Register   |

### 8.13.6 Register Description

#### 8.13.6.1 0x0000 TWI Slave Address Register (Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: TWI_ADDR                                                                                                                                                                         |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                     |
| 31:8           | /          | /           | /                                                                                                                                                                                               |
| 7:1            | R/W        | 0x0         | SLA<br>Slave Address<br>For 7-bit addressing, the bit[7:1] indicates:<br>SLA6, SLA5, SLA4, SLA3, SLA2, SLA1, SLA0<br>For 10-bit addressing, the bit[7:1] indicates:<br>1, 1, 1, 1, 0, SLAX[9:8] |
| 0              | R/W        | 0x0         | GCE<br>General Call Address Enable<br>0: Disable<br>1: Enable                                                                                                                                   |



## NOTE

For 7-bit addressing:

SLA6 – SLA0 is the 7-bit address of the TWI in slave mode. When the TWI receives this address after a START condition, it will generate an interrupt and enter slave mode. (SLA6 corresponds to the first bit received from the TWI bus.) If GCE is set to '1', the TWI will also recognize the general call address (00h).

For 10-bit addressing:

When the address received starts with b'11110, the TWI recognizes b'11110 as the first part of a 10-bit address and if the next two bits match ADDR[2:1] (For example, SLAX9 and SLAX8 for the extended address of the device), it sends an ACK. (The device does not generate an interrupt at this point.) If the next byte of the address matches the XADDR register (SLAX7 – SLAX0), the TWI generates an interrupt and goes into slave mode.

#### 8.13.6.2 0x0004 TWI Extend Address Register (Default Value: 0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: TWI_XADDR                  |
|----------------|------------|-------------|-------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                               |
| 31:8           | /          | /           | /                                         |
| 7:0            | R/W        | 0x0         | SLAX<br>Extend Slave Address<br>SLAX[7:0] |

#### 8.13.6.3 0x0008 TWI Data Register (Default Value: 0x0000\_0000)

| Offset: 0x0008 |            |             | Register Name: TWI_DATA                       |
|----------------|------------|-------------|-----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                   |
| 31:8           | /          | /           | /                                             |
| 7:0            | R/W        | 0x0         | TWI_DATA<br>Data byte transmitted or received |

#### 8.13.6.4 0x000C TWI Control Register (Default Value: 0x0000\_0000)

| Offset: 0x000C |            |             | Register Name: TWI_CNTR                                        |
|----------------|------------|-------------|----------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                    |
| 31:8           | /          | /           | /                                                              |
| 7              | R/W        | 0x0         | INT_EN<br>Interrupt Enable<br>0: The interrupt line always low |

| Offset: 0x000C |            |             | Register Name: TWI_CNTR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                |            |             | 1: The interrupt line will go high when INT_FLAG is set.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 6              | R/W        | 0x0         | <p>BUS_EN<br/>TWI Bus Enable<br/>0: The TWI bus SDA/SCL is ignored and the TWI controller will not respond to any address on the bus.<br/>1: The TWI will respond to call to its slave address – and to the general call address if the GCE bit in the ADDR register is set.<br/>Note: In master operation mode, this bit should be set to '1'.</p>                                                                                                                                                                                                                                                                                                                        |
| 5              | R/WAC      | 0x0         | <p>M_STA<br/>Master Mode Start<br/>When the M_STA is set to '1', the TWI controller enters master mode and will transmit a START condition on the bus when the bus is free. If the M_STA bit is set to '1' when the TWI controller is already in master mode and one or more bytes have been transmitted, then a repeated START condition will be sent. If the M_STA bit is set to '1' when the TWI is accessed in slave mode, the TWI will complete the data transfer in slave mode then enter master mode when the bus has been released.<br/>The M_STA bit is cleared automatically after a START condition has been sent. Writing a '0' to this bit has no effect.</p> |
| 4              | R/W1C      | 0x0         | <p>M_STP<br/>Master Mode Stop<br/>If the M_STP is set to '1' in master mode, a STOP condition is transmitted on the TWI bus. If the M_STP bit is set to '1' in slave mode, the TWI will indicate if a STOP condition has been received, but no STOP condition will be transmitted on the TWI bus. If both M_STA and M_STP bits are set, the TWI will first transmit the STOP condition (if in master mode), then transmit the START condition.<br/>The M_STP bit is cleared automatically. Writing a '0' to this bit has no effect.</p>                                                                                                                                    |
| 3              | R/W1C      | 0x0         | <p>INT_FLAG<br/>Interrupt Flag<br/>The INT_FLAG is automatically set to '1' when any of the 28 (out of the possible 29) states is entered (see</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

| Offset: 0x000C |            |             | Register Name: TWI_CNTR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                |            |             | 'STAT Register' below). The state that does not set INT_FLAG is state F8h. If the INT_EN bit is set, the interrupt line goes high when INT_FLAG is set to '1'. If the TWI is operating in slave mode, the data transfer is suspended when INT_FLAG is set and the low period of the TWI bus clock line (SCL) is stretched until '1' is written to INT_FLAG. The TWI clock line is then released and the interrupt line goes low.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 2              | R/W        | 0x0         | <p>A_ACK<br/>Assert Acknowledge</p> <p>When A_ACK is set to '1', an Acknowledge (low level on SDA) will be sent during the acknowledge clock pulse on the TWI bus if:</p> <ul style="list-style-type: none"> <li>(1). Either the whole of a matching 7-bit slave address or the first or the second byte of a matching 10-bit slave address has been received.</li> <li>(2). The general call address has been received and the GCE bit in the ADDR register is set to '1'.</li> <li>(3). A data byte has been received in master or slave mode.</li> </ul> <p>When A_ACK is '0', a Not Acknowledge (high level on SDA) will be sent when a data byte is received in master or slave mode.</p> <p>If A_ACK is cleared to '0' in slave transmitter mode, the byte in the DATA register is assumed to be the 'last byte'. After this byte has been transmitted, the TWI will enter state C8h then return to the idle state (status code F8h) when INT_FLAG is cleared.</p> <p>The TWI will not respond as a slave unless A_ACK is set.</p> |
| 1              | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 0              | R/W        | 0x0         | <p>CLK_COUNT_MODE</p> <p>0: scl clock high period count on oscl</p> <p>1: scl clock high period count on iscl</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

#### 8.13.6.5 0x0010 TWI Status Register (Default Value: 0x0000\_00F8)

| Offset: 0x0010 |            |             | Register Name: TWI_STAT |
|----------------|------------|-------------|-------------------------|
| Bit            | Read/Write | Default/Hex | Description             |
| 31:8           | /          | /           | /                       |
| 7:0            | R          | 0xF8        | STA                     |

| Offset: 0x0010 |            |             | Register Name: TWI_STAT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                |            |             | Status Information Byte<br>Code Status<br>0x00: Bus error<br>0x08: START condition transmitted<br>0x10: Repeated START condition transmitted<br>0x18: Address + Write bit transmitted, ACK received<br>0x20: Address + Write bit transmitted, ACK not received<br>0x28: Data byte transmitted in master mode, ACK received<br>0x30: Data byte transmitted in master mode, ACK not received<br>0x38: Arbitration lost in address or data byte<br>0x40: Address + Read bit transmitted, ACK received<br>0x48: Address + Read bit transmitted, ACK not received<br>0x50: Data byte received in master mode, ACK transmitted<br>0x58: Data byte received in master mode, not ACK transmitted<br>0x60: Slave address + Write bit received, ACK transmitted<br>0x68: Arbitration lost in the address as master, slave address + Write bit received, ACK transmitted<br>0x70: General Call address received, ACK transmitted<br>0x78: Arbitration lost in the address as master, General Call address received, ACK transmitted<br>0x80: Data byte received after slave address received, ACK transmitted<br>0x88: Data byte received after slave address received, not ACK transmitted<br>0x90: Data byte received after General Call received, ACK transmitted<br>0x98: Data byte received after General Call received, not ACK transmitted<br>0xA0: STOP or repeated START condition received in slave mode<br>0xA8: Slave address + Read bit received, ACK transmitted<br>0xB0: Arbitration lost in the address as master, slave address + Read bit received, ACK transmitted<br>0xB8: Data byte transmitted in slave mode, ACK |

| Offset: 0x0010 |            |             | Register Name: TWI_STAT                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                |            |             | <p>received<br/>           0xC0: Data byte transmitted in slave mode, ACK not received<br/>           0xC8: The Last byte transmitted in slave mode, ACK received<br/>           0xD0: Second Address byte + Write bit transmitted, ACK received<br/>           0xD8: Second Address byte + Write bit transmitted, ACK not received<br/>           0xF8: No relevant status information, INT_FLAG=0<br/>           Others: Reserved</p> |

#### 8.13.6.6 0x0014 TWI Clock Register (Default Value: 0x0000\_0080)

| Offset: 0x0014 |            |             | Register Name: TWI_CCR                                                                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                     |
| 31:9           | /          | /           | /                                                                                                                                                                                                                                                                                                                                               |
| 8              | R/W        | 0x0         | <p>CLK_DUTY_30_EN<br/>           Enabling duty cycle 30% of Clock as Master<br/>           0: bit [7] takes effect<br/>           1: 30%</p>                                                                                                                                                                                                    |
| 7              | R/W        | 0x1         | <p>CLK_DUTY<br/>           Setting duty cycle of clock as master<br/>           0: 50%<br/>           1: 40%</p>                                                                                                                                                                                                                                |
| 6:3            | R/W        | 0x0         | <p>CLK_M<br/>           The TWI SCL output frequency, in master mode, is F1/10:<br/> <math>F1 = F0/(CLK\_M + 1)</math><br/> <math>F_{SCL} = F1/10 = Fin/(2^{CLK\_N} * (CLK\_M + 1) * 10)</math><br/>           Specially, <math>F_{SCL} = F1/11</math> when <math>CLK\_M=0</math> and CLK_DUTY=40% due to the delay of SCL sample debounce.</p> |
| 2:0            | R/W        | 0x0         | <p>CLK_N<br/>           The TWI bus is sampled by the TWI at the frequency defined by F0:<br/> <math>F_{SAMP} = F0 = Fin/2^{CLK\_N}</math><br/>           The TWI SCL output frequency, in master mode, is F1/10:<br/> <math>F1 = F0/(CLK\_M + 1)</math><br/> <math>F_{SCL} = F1/10 = Fin/(2^{CLK\_N} * (CLK\_M + 1) * 10)</math></p>           |

| Offset: 0x0014 |            |             | Register Name: TWI_CCR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                |            |             | <p>Specially, <math>F_{SCL} = F_1/11</math> when <math>CLK\_M=0</math> and <math>CLK\_DUTY=40\%</math> due to the delay of SCL sample debounce.</p> <p>For Example:</p> <p><math>F_{IN} = 24 \text{ MHz}</math> (APB clock input)</p> <p>For 400 kHz full speed 2-wire, <math>CLK\_N = 1</math>, <math>CLK\_M = 2</math></p> $F_0 = 24 \text{ MHz}/2^1 = 12 \text{ MHz}$ , $F_1 = F_0/(10^{*(2+1)}) = 0.4 \text{ MHz}$ <p>For 100 kHz standard speed 2-wire, <math>CLK\_N = 1</math>, <math>CLK\_M = 11</math></p> $F_0 = 24 \text{ MHz}/2^1 = 12 \text{ MHz}$ , $F_1 = F_0/(10^{*(11+1)}) = 0.1 \text{ MHz}$ |

#### 8.13.6.7 0x0018 TWI Soft Reset Register (Default Value: 0x0000\_0000)

| Offset: 0x0018 |            |             | Register Name: TWI_SRST                                                                                                             |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                         |
| 31:1           | /          | /           | /                                                                                                                                   |
| 0              | R/WAC      | 0x0         | <p>SOFT_RST<br/>Soft Reset</p> <p>Write '1' to this bit to reset the TWI and clear to '0' when completing Soft Reset operation.</p> |

#### 8.13.6.8 0x001C TWI Enhance Feature Register (Default Value: 0x0000\_0000)

| Offset: 0x001C |            |             | Register Name: TWI_EFR                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                             |
| 31:2           | /          | /           | /                                                                                                                                                                                                                                                                                                                       |
| 1:0            | R/W        | 0x0         | <p>DBN<br/>Data Byte Number Follow Read Command Control</p> <p>00: No data byte can be written after the read command</p> <p>01: Only 1-byte data can be written after the read command</p> <p>10: 2-bytes data can be written after the read command</p> <p>11: 3-bytes data can be written after the read command</p> |

#### 8.13.6.9 0x0020 TWI Line Control Register (Default Value: 0x0000\_003A)

| Offset: 0x0020 |            |             | Register Name: TWI_LCR                                                                                                                                                                                             |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                        |
| 31:6           | /          | /           | /                                                                                                                                                                                                                  |
| 5              | R          | 0x1         | SCL_STATE<br>Current State of TWI_SCL<br>0: Low<br>1: High                                                                                                                                                         |
| 4              | R          | 0x1         | SDA_STATE<br>Current State of TWI_SDA<br>0: Low<br>1: High                                                                                                                                                         |
| 3              | R/W        | 0x1         | SCL_CTL<br>TWI_SCL Line State Control Bit<br>When the line control mode is enabled (bit[2] is set), this bit decides the output level of TWI_SCL.<br>0: Output low level<br>1: Output high level                   |
| 2              | R/W        | 0x0         | SCL_CTL_EN<br>TWI_SCL Line State Control Enable<br>When this bit is set, the state of TWI_SCL is controlled by the value of bit[3].<br>0: Disable TWI_SCL line control mode<br>1: Enable TWI_SCL line control mode |
| 1              | R/W        | 0x1         | SDA_CTL<br>TWI_SDA Line State Control Bit<br>When the line control mode is enabled (bit[0] is set), this bit decides the output level of TWI_SDA.<br>0: Output low level<br>1: Output high level                   |
| 0              | R/W        | 0x0         | SDA_CTL_EN<br>TWI_SDA Line State Control Enable<br>When this bit is set, the state of TWI_SDA is controlled by the value of bit[1].<br>0: Disable TWI_SDA line control mode<br>1: Enable TWI_SDA line control mode |

#### 8.13.6.10 0x0200 TWI\_DRV Control Register (Default Value: 0x00F8\_1000)

| Offset: 0x0200 |            |             | Register Name: TWI_DRV_CTRL |
|----------------|------------|-------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                 |
| 31             | R/WAC      | 0x0         | START_TRAN                  |

| Offset: 0x0200 |            |             | Register Name: TWI_DRV_CTRL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                |            |             | Start transmission<br>0: Transmission idle<br>1: Start transmission<br>Automatically cleared to '0' when finished. If the slave is not responding for the expected status over the time defined by TIMEOUT, the current transmission will stop. All setting formats and data will be loaded from registers and FIFO when the transmission starts.                                                                                                                                                                                  |
| 30             | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 29             | R/W        | 0x0         | RESTART_MODE<br>Restart mode<br>0: RESTART<br>1: STOP+START<br>Define the TWI_DRV action after sending the register address.                                                                                                                                                                                                                                                                                                                                                                                                       |
| 28             | R/W        | 0x0         | READ_TRAN_MODE<br>Read transition mode<br>0: Send slave_id+W<br>1: Not send slave_id+W<br>Setting this bit to 1 if reading from a slave in which the register width is equal to 0.                                                                                                                                                                                                                                                                                                                                                 |
| 27:24          | R          | 0x0         | TRAN_RESULT<br>Transition result<br>000: OK<br>001: FAIL<br>Other: Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 23:16          | R          | 0xf8        | TWI_STA<br>TWI status<br>0x00: bus error<br>0x08: START condition transmitted<br>0x10: Repeated START condition transmitted<br>0x18: Address + Write bit transmitted, ACK received<br>0x20: Address + Write bit transmitted, ACK not received<br>0x28: Data byte transmitted in master mode, ACK received<br>0x30: Data byte transmitted in master mode, ACK not received<br>0x38: Arbitration lost in address or data byte<br>0x40: Address + Read bit transmitted, ACK received<br>0x48: Address + Read bit transmitted, ACK not |

| Offset: 0x0200 |            |             | Register Name: TWI_DRV_CTRL                                                                                                                                                                                                                                         |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                         |
|                |            |             | received<br>0x50: Data byte received in master mode, ACK received<br>0x58: Data byte received in master mode, ACK not received<br>0x01: Timeout when sending the 9 <sup>th</sup> SCL clock<br>Other: Reserved                                                       |
| 15:8           | R/W        | 0x10        | <b>TIMEOUT_N</b><br>Timeout number<br>When sending the 9 <sup>th</sup> clock, assert fail signal when the slave device does not respond after N*F <sub>SCL</sub> cycles. And the software must do a reset to the TWI_DRV module and send a stop condition to slave. |
| 7:2            | /          | /           | /                                                                                                                                                                                                                                                                   |
| 1              | R/W        | 0x0         | <b>SOFT_RESET</b><br>Software reset<br>0: Normal<br>1: Reset                                                                                                                                                                                                        |
| 0              | R/W        | 0x0         | <b>TWI_DRV_EN</b><br>TWI driver enable<br>0: Module disable<br>1: Module enable (only use in TWI Master Mode)                                                                                                                                                       |

#### 8.13.6.11 0x0204 TWI\_DRV Transmission Configuration Register (Default Value: 0x0000\_0001)

| Offset: 0x0204 |            |             | Register Name: TWI_DRV_CFG                                                                               |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                              |
| 31:16          | R/W        | 0x0         | <b>PKT_INTERVAL</b><br>Define the interval between each packet for PKT_INTERVAL F <sub>SCL</sub> cycles. |
| 15:0           | R/W        | 0x1         | <b>PACKET_CNT</b><br>The FIFO data is transmitted as PACKET_CNT packets in current format.               |

#### 8.13.6.12 0x0208 TWI\_DRV Slave ID Register (Default Value: 0x0000\_0000)

| Offset: 0x0208 |            |             | Register Name: TWI_DRV_SLV |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:16          | /          | /           | /                          |
| 15:9           | R/W        | 0x0         | SLV_ID                     |

| Offset: 0x0208 |            |             | Register Name: TWI_DRV_SLV                                                                                                                                                                 |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                |
|                |            |             | Slave device ID<br>For 7-bit addressing, the bit[7:1] indicates:<br>SLA6, SLA5, SLA4, SLA3, SLA2, SLA1, SLA0<br>For 10-bit addressing, the bit[7:1] indicates:<br>1, 1, 1, 1, 0, SLAX[9:8] |
| 8              | R/W        | 0x0         | CMD<br>R/W operation to slave device<br>0: Write<br>1: Read                                                                                                                                |
| 7:0            | R/W        | 0x0         | SLV_ID_X<br>SLAX[7:0]<br>The low 8 bits for slave device ID with 10-bit addressing.                                                                                                        |

#### 8.13.6.13 0x020C TWI\_DRV Packet Format Register (Default Value: 0x0001\_0001)

| Offset: 0x020C |            |             | Register Name: TWI_DRV_FMT                                               |
|----------------|------------|-------------|--------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                              |
| 31:24          | /          | /           | /                                                                        |
| 23:16          | R/W        | 0x1         | ADDR_BYTE<br>How many bytes be sent as slave device reg address<br>0-255 |
| 15:0           | R/W        | 0x1         | DATA_BYTE<br>How many bytes be sent/received as data<br>1-65535          |

#### 8.13.6.14 0x0210 TWI\_DRV Bus Control Register (Default Value: 0x0000\_80C0)

| Offset: 0x0210 |            |             | Register Name: TWI_DRV_BUS_CTRL                                                                                        |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                            |
| 31:18          | /          | /           | /                                                                                                                      |
| 17             | R/W        | 0x0         | CLK_DUTY_30_EN<br>Enabling duty cycle 30% of Clock as Master<br>0: bit [15] takes effect<br>1: 30%                     |
| 16             | W          | 0x0         | CLK_COUNT_MODE<br>Clock count mode<br>0: scl clock high period count on oscl<br>1: scl clock high period count on iscl |
| 15             | R/W        | 0x1         | CLK_DUTY                                                                                                               |

| Offset: 0x0210 |            |             | Register Name: TWI_DRV_BUS_CTRL                                                                                                                                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                 |
|                |            |             | Setting duty cycle of clock as Master<br>0: 50%<br>1: 40%                                                                                                                                   |
| 14:12          | R/W        | 0x0         | CLK_N<br>TWI_DRV bus sampling clock F0=24MHz/2^CLK_N                                                                                                                                        |
| 11:8           | R/W        | 0x0         | CLK_M<br>TWI_DRV output SCL frequency is<br>$F_{SCL} = F1/10 = (F0/(CLK\_M+1))/10$<br>Specially, Foscl = F1/11 when CLK_M=0 and<br>CLK_DUTY=40% due to the delay of SCL sample<br>debounce. |
| 7              | R          | 0x1         | SCL_STA<br>SCL current status                                                                                                                                                               |
| 6              | R          | 0x1         | SDA_STA<br>SDA current status                                                                                                                                                               |
| 5:4            | /          | /           | /                                                                                                                                                                                           |
| 3              | R/W        | 0x0         | SCL_MOV<br>SCL manual output value                                                                                                                                                          |
| 2              | R/W        | 0x0         | SDA_MOV<br>SDA manual output value                                                                                                                                                          |
| 1              | R/W        | 0x0         | SCL_MOE<br>SCL manual output enable                                                                                                                                                         |
| 0              | R/W        | 0x0         | SDA_MOE<br>SDA manual output enable                                                                                                                                                         |

#### 8.13.6.15 0x0214 TWI\_DRV Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0214 |            |             | Register Name: TWI_DRV_INT_CTRL                                        |
|----------------|------------|-------------|------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                            |
| 31:18          | /          | /           | /                                                                      |
| 19             | R/W        | 0x0         | RX_REQ_INT_EN<br>If set, an interrupt is sent when RX_REQ_PD sets.     |
| 18             | R/W        | 0x0         | TX_REQ_INT_EN<br>If set, an interrupt is sent when TX_REQ_PD sets.     |
| 17             | R/W        | 0x0         | TRAN_ERR_INT_EN<br>If set, an interrupt is sent when TRAN_ERR_PD sets. |
| 16             | R/W        | 0x0         | TRAN_COM_INT_EN<br>If set, an interrupt is sent when TRAN_COM_PD sets. |
| 15:4           | /          | /           | /                                                                      |
| 3              | R/W1C      | 0x0         | RX_REQ_PD                                                              |

| Offset: 0x0214 |            |             | Register Name: TWI_DRV_INT_CTRL                                                         |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                             |
|                |            |             | Set when the data byte number in RECV_FIFO reaches RX_TRIG.                             |
| 2              | R/W1C      | 0x0         | TX_REQ_PD<br>Set when there is no less than DMA_TX_TRIG empty byte number in SEND_FIFO. |
| 1              | R/W1C      | 0x0         | TRAN_ERR_PD<br>Packet transmission failure pending                                      |
| 0              | R/W1C      | 0x0         | TRAN_COM_PD<br>Packet transmission completion pending                                   |

#### 8.13.6.16 0x0218 TWI\_DRV DMA Configure Register (Default Value: 0x0010\_0010)

| Offset: 0x0218 |            |             | Register Name: TWI_DRV_DMA_CFG                                                                                                                                                                                                                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                     |
| 31:25          | /          | /           | /                                                                                                                                                                                                                                                               |
| 24             | R/W        | 0x0         | DMA_RX_EN<br>DMA RX Enable                                                                                                                                                                                                                                      |
| 23:22          | /          | /           | /                                                                                                                                                                                                                                                               |
| 21:16          | R/W        | 0x10        | RX_TRIGGER<br>RX trigger<br>When DMA_RX_EN is set, send DMA RX Req when the data byte number in RECV_FIFO reaches RX_TRIGGER, or the read transmission is completed, the data of RECV_FIFO does not reach RX_TRIGGER but as long as the RECV_FIFO is not empty. |
| 15:9           | /          | /           | /                                                                                                                                                                                                                                                               |
| 8              | R/W        | 0x0         | DMA_TX_EN<br>DMA TX Enable                                                                                                                                                                                                                                      |
| 7:6            | /          | /           | /                                                                                                                                                                                                                                                               |
| 5:0            | R/W        | 0x10        | TX_TRIGGER<br>TX trigger<br>When DMA_TX_EN is set, send DMA TX Req when the space of SEND_FIFO (FIFO Level – data volume) reaches TX_TRIGGER.                                                                                                                   |

#### 8.13.6.17 0x021C TWI\_DRV FIFO Content Register (Default Value: 0x0000\_0000)

| Offset: 0x021C |            |             | Register Name: TWI_DRV_FIFO_CON |
|----------------|------------|-------------|---------------------------------|
| Bit            | Read/Write | Default/Hex | Description                     |
| 31:23          | /          | /           | /                               |

| Offset: 0x021C |            |             | Register Name: TWI_DRV_FIFO_CON                                                                    |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                        |
| 22             | R/WAC      | 0x0         | RECV_FIFO_CLEAR<br>Set this bit to clear RECV_FIFO pointer, and this bit is cleared automatically. |
| 21:16          | R          | 0x0         | RECV_FIFO_CONTENT<br>The number of data in RECV_FIFO                                               |
| 15:7           | /          | /           | /                                                                                                  |
| 6              | R/WAC      | 0x0         | SEND_FIFO_CLEAR<br>Set this bit to clear SEND_FIFO pointer, and this bit is cleared automatically. |
| 5:0            | R          | 0x0         | SEND_FIFO_CONTENT<br>The number of data in SEND_FIFO                                               |

#### 8.13.6.18 0x0300 TWI\_DRV Send Data FIFO Access Register (Default Value: 0x0000\_0000)

| Offset: 0x0300 |            |             | Register Name: TWI_DRV_SEND_FIFO_ACC                                                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                   |
| 31:8           | /          | /           | /                                                                                                             |
| 7:0            | W          | 0x0         | SEND_DATA_FIFO<br>Address of a 32x8 SEND_FIFO, which stores reg address and data sending to the slave device. |

#### 8.13.6.19 0x0304 TWI\_DRV Receive Data FIFO Access Register (Default Value: 0x0000\_0000)

| Offset: 0x0304 |            |             | Register Name: TWI_DRV_RECV_FIFO_ACC                                                             |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                      |
| 31:8           | /          | /           | /                                                                                                |
| 7:0            | R          | 0x0         | RECV_DATA_FIFO<br>Address of a 32x8 RECV_FIFO, which stores data received from the slave device. |

## 8.14 PWM

### 8.14.1 Overview

The Pulse Width Modulation (PWM) module can output the configurable PWM waveforms and measure the external input waveforms.

The PWM has the following features:

- Up to 30 PWM channels and 4 PWM controllers: PWM [19:0] in CPUX domain, S-PWM [9:0] in CPUS domain
  - PWM [15:0] for PWMCTRL0 controller
  - PWM [19:16] for PWMCTRL1 controller
  - S-PWM [1:0] for S\_PWMCTRL controller
  - S-PWM [9:2] for MCU\_PWMCTRL controller
- Maximum 16 independent PWM channels for PWM controller
  - Supports PWM continuous mode output
  - Supports PWM pulse mode output, and the pulse number is configurable
  - Output frequency range:
    - 0 to 24 MHz (when the clock source is DCXO24M)
    - 0 to 100 MHz (when the clock source is APB1 clock)
  - Various duty-cycle: 0% to 100%
  - Minimum resolution: 1/65536
- Maximum 8 complementary pairs output
  - The pairing methods for each controller are as follows. The components are internal PWM channels:
    - Maximum 8 pairs for PWMCTRL0:  
PWM0 + PWM1, PWM2 + PWM3, PWM4 + PWM5, PWM6 + PWM7, PWM8 + PWM9,  
PWM10 + PWM11, PWM12 + PWM13, PWM14 + PWM15
    - Maximum 2 pairs for PWMCTRL1:  
PWM0+PWM1, PWM2+PWM3
    - Maximum 1 pair for S\_PWMCTRL:  
PWM0+PWM1
    - Maximum 4 pairs for MCU\_PWMCTRL:  
PWM0+PWM1, PWM2+PWM3, PWM4+PWM5, PWM6+PWM7
  - Supports dead-zone generator, and the dead-zone time is configurable

- Maximum 4 group of PWM channel output for controlling stepping motors
  - Supports any plural channels to form a group, and output the same duty-cycle pulse
  - In group mode, the relative phase of the output waveform for each channel is configurable
- Maximum 16 channels capture input
  - Supports rising edge detection and falling edge detection for input waveform pulse
  - Supports pulse-width measurement for input waveform pulse

The basic features for four PWM controllers are as follows:

| PWM controller | Domain | Channels | Pairs                                                                                                                                                                                     |
|----------------|--------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PWMCTRL0       | CPUX   | 16       | 8 PWM pairs<br>PWM01 (PWM0+PWM1)<br>PWM23 (PWM2+PWM3)<br>PWM45 (PWM4+PWM5)<br>PWM67 (PWM6+PWM7)<br>PWM89 (PWM8+PWM9)<br>PWMAb (PWM10+PWM11)<br>PWMcD (PWM12+PWM13)<br>PWMeF (PWM14+PWM15) |
| PWMCTRL1       | CPUX   | 4        | 2 PWM pairs<br>PWM01 (PWM0+PWM1)<br>PWM23 (PWM2+PWM3)                                                                                                                                     |
| S_PWMCTRL      | CPUS   | 2        | 1 PWM pair<br>PWM01 (PWM0+PWM1)                                                                                                                                                           |
| MCU_PWMCTRL    | CPUS   | 8        | 4 PWM pair<br>PWM01 (PWM0+PWM1)<br>PWM23 (PWM2+PWM3)<br>PWM45 (PWM4+PWM5)<br>PWM67 (PWM6+PWM7)                                                                                            |



For the corresponding relationship between the channels of each PWM controller and the external signals, please refer to section 8.14.3.1 External Signals.

### 8.14.2 Block Diagram

The PWM includes multi PWM channels. Each channel can generate different PWM waveform by the independent counter and duty-ratio configuration register. Each PWM pair shares one group of clock and dead-zone generator to generate PWM waveform.

Figure 8-54 PWM Block Diagram



Each PWM pair consists of 1 clock module, 2 timer logic module, and 1 programmable dead-zone generator.

### 8.14.3 Functional Description

#### 8.14.3.1 External Signals

The following table describes the external signals of the PWM.

Table 8-38 PWM External Signals

| Signal          | Description               | Type |
|-----------------|---------------------------|------|
| <b>PWMCTRL0</b> |                           |      |
| PWM0            | PWM channel0 in PWMCTRL0  | I/O  |
| PWM1            | PWM channel1 in PWMCTRL0  | I/O  |
| PWM2            | PWM channel2 in PWMCTRL0  | I/O  |
| PWM3            | PWM channel3 in PWMCTRL0  | I/O  |
| PWM4            | PWM channel4 in PWMCTRL0  | I/O  |
| PWM5            | PWM channel5 in PWMCTRL0  | I/O  |
| PWM6            | PWM channel6 in PWMCTRL0  | I/O  |
| PWM7            | PWM channel7 in PWMCTRL0  | I/O  |
| PWM8            | PWM channel8 in PWMCTRL0  | I/O  |
| PWM9            | PWM channel9 in PWMCTRL0  | I/O  |
| PWM10           | PWM channel10 in PWMCTRL0 | I/O  |
| PWM11           | PWM channel11 in PWMCTRL0 | I/O  |
| PWM12           | PWM channel12 in PWMCTRL0 | I/O  |
| PWM13           | PWM channel13 in PWMCTRL0 | I/O  |

| Signal             | Description                 | Type |
|--------------------|-----------------------------|------|
| PWM14              | PWM channel14 in PWMCTRL0   | I/O  |
| PWM15              | PWM channel15 in PWMCTRL0   | I/O  |
| <b>PWMCTRL1</b>    |                             |      |
| PWM16              | PWM channel0 in PWMCTRL1    | I/O  |
| PWM17              | PWM channel1 in PWMCTRL1    | I/O  |
| PWM18              | PWM channel2 in PWMCTRL1    | I/O  |
| PWM19              | PWM channel3 in PWMCTRL1    | I/O  |
| <b>S_PWMCTRL</b>   |                             |      |
| S-PWM0             | PWM channel0 in S_PWMCTRL   | I/O  |
| S-PWM1             | PWM channel1 in S_PWMCTRL   | I/O  |
| <b>MCU_PWMCTRL</b> |                             |      |
| S-PWM2             | PWM channel0 in MCU_PWMCTRL | I/O  |
| S-PWM3             | PWM channel1 in MCU_PWMCTRL | I/O  |
| S-PWM4             | PWM channel2 in MCU_PWMCTRL | I/O  |
| S-PWM5             | PWM channel3 in MCU_PWMCTRL | I/O  |
| S-PWM6             | PWM channel4 in MCU_PWMCTRL | I/O  |
| S-PWM7             | PWM channel5 in MCU_PWMCTRL | I/O  |
| S-PWM8             | PWM channel6 in MCU_PWMCTRL | I/O  |

#### 8.14.3.2 Clock Sources

The following table describes the clock sources of the PWM controllers.

**Table 8-39 PWM clock sources**

| PWM                      | Clock Sources | Description                   | Module |
|--------------------------|---------------|-------------------------------|--------|
| PWMCTRL0                 | HOSC          | 24 MHz, external clock.       | CCU    |
| PWMCTRL1                 | APB1_CLK      | 24 MHz, PWM bus clock.        |        |
| S_PWMCTRL<br>MCU_PWMCTRL | CLK24M        | By default, CLK24M is 24 MHz. | PRCM   |
|                          | CLK32K        | By default, CLK32K is 32 kHz. |        |
|                          | CLK_RC        | By default, CLK_RC is 16 MHz. |        |

#### 8.14.3.3 Typical Application

- Suitable for display device, such as LCD
- Suitable for electric motor control

### 8.14.3.4 Clock Controller

Using PWM01 as an example. The other PWM pairs are the same as PWM01.

Figure 8-55 PWM01 Clock Controller Diagram



The clock controller of each PWM pair includes clock source select ([PWM01\\_CLK\\_SRC](#)), 1-256 scaler ([PWM01\\_CLK\\_DIV\\_M](#)). Each PWM channel has the secondary frequency division ([PWM\\_PRESCAL\\_K](#)), clock source bypass ([PWMx\\_CLK\\_BYPASS](#)) and clock switch ([PWMx\\_CLK\\_GATING](#)).

The clock sources have HOSC and APB0. The HOSC comes from the external high-frequency oscillator; the APB0 is APB0 bus clock.

The bypass function of the clock source is that the clock source directly accesses PWM output, the PWM output waveform is the waveform of the clock controller output. The BYPASS gridlines in the above figure indicate the bypass function of the clock source, see Figure 8-56 for the details about implement. At last, the output clock of the clock controller is sent to the PWM logic module.

### 8.14.3.5 PWM Output

Taking PWM01 as an example, Figure 8-56 indicates the PWM01 output logic diagram. The logic diagrams of other PWM pairs are the same as PWM01.

The timer logic module of PWM consists of one 16-bit up-counter ([PCNTR](#)) and three 16-bit parameters ([PWM\\_ENTIRE\\_CYCLE](#), [PWM\\_ACT\\_CYCLE](#), [PWM\\_COUNTER\\_START](#)). The [PWM\\_ENTIRE\\_CYCLE](#) is used to control the PWM cycle, the [PWM\\_ACT\\_CYCLE](#) is used to control the duty-cycle, the [PWM\\_COUNTER\\_START](#) is used to control the output phase (multi-channel synchronization work requirements).

The [PWM\\_ENTIRE\\_CYCLE](#) and the [PWM\\_ACT\\_CYCLE](#) support the cache load, after PWM output is enabled, the register values of the [PWM\\_ENTIRE\\_CYCLE](#) and the [PWM\\_ACT\\_CYCLE](#) can be changed anytime, the changed value caches into the cache register. When the [PCNTR](#) counter outputs a period of PWM waveform, the value of the cache register can be updated for the [PCNTR](#)

control. The purpose of the cache load is to avoid the unstable PWM output waveform with glitches when updating the values of the [PWM\\_ENTIRE\\_CYCLE](#) and [PWM\\_ACT\\_CYCLE](#).

The PWM supports cycle and pulse waveform output.

**Cycle mode:** The PWM outputs the setting PWM waveform continually, that is, the output waveform is a continuous PWM square wave.

**Pulse mode:** After setting the [PWM\\_PUL\\_NUM](#) parameter, the PWM outputs (PWM\_PULNUM+1) periods of PWM waveform, that is, the waveform with several pulses are output.

Figure 8-56 PWM01 Output Logic Module Diagram



#### 8.14.3.6 Pulse Mode and Cycle Mode

The PWM output supports pulse mode and cycle mode. PWM in pulse mode outputs [PCR\[PWM\\_PUL\\_NUM\]](#) +1 cycles waveform, but PWM in cycle mode outputs continuous waveform. The following figure shows the PWM output waveform in pulse mode and cycle mode.

Figure 8-57 PWM0 Output Waveform in Pulse Mode and Cycle Mode



Each channel of the PWM module supports the PWM output of pulse mode and cycle mode, the active state of the PWM output waveform can be programmed to control.

When [PCR\[PWM\\_MODE\]](#) is 0, the PWM0 outputs in cycle mode. When [PCR\[PWM\\_MODE\]](#) is 1, the PWM0 outputs in pulse mode.

Specifically, in pulse mode, after the PWM0 channel enabled, [PCR\[PWM\\_PUL\\_START\]](#) needs to be set to 1 when the PWM0 needs to output pulse waveform, after completed the output, [PCR\[PWM\\_PUL\\_START\]](#) can be cleared to 0 by hardware. The next setting 1 can be operated after [PCR\[PWM\\_PUL\\_START\]](#) is cleared.

#### 8.14.3.7 Complementary Pair Output

Every PWM pair supports complementary pair output and PWM pair with dead-time. the following figure shows the complementary pair output of PWM01.

Figure 8-58 PWM01 Complementary Pair Output



The complementary pair output needs to satisfy the following conditions:

- PWM0 and PWM1 have the same clock divider, frequency, duty-cycle, and phase
- PWM0 and PWM1 have an opposite active state
- Enable the clock gating of PWM0 and PWM1 at the same time
- Enable the waveform output of PWM0 and PWM1 at the same time

#### 8.14.3.8 Dead-time Generator

Every PWM pair has a programmable dead-time generator. When the dead-time function of the PWM pair enabled, the PWM01 output waveform is decided by PWM timer logic and DeadZone Generator. the following figure shows the output waveform.

**Figure 8-59 Dead-time Output Waveform**



The PWM waveform before the insertion of dead-time indicates a complementary waveform pair of non-inserted dead-time in Dead Zone Generator 01.

The PWM waveform after the insertion of dead-time indicates a non-complementary PWM waveform pair inserted dead-time in a complementary waveform pair of Dead Zone Generator 01. The PWM waveform pair at last outputs to PWM0 pin and PWM1 pin.

For the complementary pair of Dead Zone Generator 01, the principle of inserting dead-time is that to insert dead-time as soon as the rising edge came. If the high level time for mark② in the above figure is less than dead-time, then dead-time will override the high level. The setting of dead-time needs to consider the period and the duty-cycle of the output waveform. The dead-time formula is defined as follows:

$$\text{Dead-time} = (\text{PWM01_CLK} / \text{PWM0_PRESCALE_K})^{-1} * \text{PDZINTV01}$$

### 8.14.3.9 PWM Group Mode

Taking PWM Group0 as an example. The same group of PWM channel is selected to work by PGR0.CS; the same [PWM\\_ENTIRE\\_CYCLE](#), [PWM\\_ACT\\_CYCLE](#) are set by the same clock configuration; the different [PWM\\_COUNTER\\_START](#) can output PWM group signals with the same duty-cycle and the different phase.

Figure 8-60 Group 0-3 PWM Signal Output



### 8.14.3.10 Capture Input

Figure 8-61 PWM01 Capture Logic Module Diagram



Besides the timer logic module of every PWM channel generates PWM output, it can be used to capture the rising edge and the falling edge of the external clock. Using the PWM0 channel as an example, the PWM0 channel has one [CFLR0](#) and one [CRLR0](#) for capturing up-counter value on the falling edge and rising edge, respectively. You can calculate the period of the external clock by [CFLR0](#) and [CRLR0](#).

$$\text{Thigh-level} = (\text{PWM01\_CLK} / \text{PWM0\_PRESCALE\_K})^{-1} * \text{CRLR0}$$

$$\text{Tlow-level} = (\text{PWM01\_CLK} / \text{PWM0\_PRESCALE\_K})^{-1} * \text{CFLR0}$$

$$\text{Period} = \text{Thigh-level} + \text{Tlow-level}$$

**Figure 8-62 PWM0 Channel Capture Timing**

When the capture input function of the PWM0 channel is enabled, the [PCNTR](#) of the PWM0 channel starts to work.

When the timer logic module of PWM0 captures a rising edge, the current value of the up-counter is locked to [CRLR0](#) and [CCR0\[CRLF\]](#) is set to 1. If [CRIEO](#) is 1, then [CRISO](#) is set to 1, the PWM0 channel sends interrupt requests, and the up-counter is loaded to 0 and continues to count. If [CRIEO](#) is 0, the timer logic module of PWM0 captures a rising edge, [CRISO](#) cannot be set to 1, the up-counter is not loaded to 0.

When the timer logic module of PWM0 captures one falling edge, the current value of [PCNTR](#) is locked to [CFLR0](#) and [CCR0\[CFLF\]](#) is set to 1. If [CFIEO](#) is 1, then [CFISO](#) is set to 1, the PWM0 channel sends interrupt requests, and the up-counter is loaded to 0 and continues to count. If [CFIEO](#) is 0, the timer logic module of PWM0 captures a falling edge, [CFISO](#) cannot be set to 1, the up-counter is not loaded to 0.

#### 8.14.4 Programming Guidelines

The following working mode takes PWM01 as an example, other PWM pairs and PWM01 are consistent.

##### 8.14.4.1 Configuring Clock

- Step 1** PWM gating: When using PWM, write 1 to [PCGR\[PWMx\\_CLK\\_GATING\]](#).
- Step 2** PWM clock source select: Set [PCCR01\[PWM01\\_CLK\\_SRC\]](#) to select HOSC or APB0 clock.
- Step 3** PWM clock divider: Set [PCCR01\[PWM01\\_CLK\\_DIV\\_M\]](#) to select different frequency division coefficient (1/2/4/8/16/32/64/128/256).
- Step 4** PWM clock bypass: Set [PCGR\[PWM\\_CLK\\_SRC\\_BYPASS\\_TO\\_PWM\]](#) to 1, output the PWM clock after the secondary frequency division to the corresponding PWM output pin.
- Step 5** PWM internal clock configuration: Set [PCR\[PWM\\_PRESCAL\\_K\]](#) to select any frequency division coefficient from 1 to 256.



#### NOTE

For the channel of complementary output and group mode, firstly, set the same clock configurations (clock source selects APB0, clock division configures the same division factor); secondly, open clock gating at the same time; thirdly, configure PWM parameters; finally, enable PWM output at the same time to ensure each channel sync.

We suggest that the two channels of the same PWM pair cannot subject to two groups because they have the same first level clock division and gating. If must allocate based on this way, the first level of clock division of the channel used by all groups needs to set to the same coefficient and open gating at the same time. And the total module needs to be reset when the group mode regroups.

#### 8.14.4.2 Configuring PWM

- Step 1** PWM mode: Set [PCR\[PWM\\_MODE\]](#) to select cycle mode or pulse mode, if pulse mode, [PCR\[PWM\\_PUL\\_NUM\]](#) needs to be configured.
- Step 2** PWM active level: Set [PCR\[PWM\\_ACT\\_STA\]](#) to select a low level or high level.
- Step 3** PWM duty-cycle: Configure [PPR\[PWM\\_ENTIRE\\_CYCLE\]](#) and [PPR\[PWM\\_ACT\\_CYCLE\]](#) after clock gating is opened.
- Step 4** PWM starting/stopping phase: Configure [PCNTR\[PWM\\_COUNTER\\_START\]](#) after the clock gating is enabled and before the PWM is enabled. You can verify whether the configuration was successful by reading back [PCNTR\[PWM\\_COUNTER\\_STATUS\]](#).
- Step 5** Enable PWM: Configure PER to select the corresponding PWM enable bit; when selecting pulse mode, [PCR\[PWM\\_PUL\\_START\]](#) needs to be enabled.

#### 8.14.4.3 Configuring Deadzone

- Step 1** Set initial value: set [PDZINTV01].
- Step 2** Enable Deadzone: set [PWM01\_DZ\_CN].

#### 8.14.4.4 Configuring Capture Input

- Step 1** Enable capture: Configure [CER](#) to enable the corresponding channel.
- Step 2** Capture mode: Configure [CCR\[CRLF\]](#) and [CCR\[CFLF\]](#) to select rising edge capture or falling edge capture, configure [CCR\[CAPINV\]](#) to select whether the input signal does reverse processing.

### 8.14.5 Register List

| Module Name | Base Address |
|-------------|--------------|
| PWMCTRL0    | 0x0200 0C00  |
| PWMCTRL1    | 0x0205 1000  |
| S_PWMCTRL   | 0x0702 0C00  |
| MCU_PWMCTRL | 0x0710 3000  |

| Register Name | Offset    | Description                        | PWMC TRL0  | PMWCT RL1 | S_PWM CTRL | MCU_PWM CTRL |
|---------------|-----------|------------------------------------|------------|-----------|------------|--------------|
| PIER          | 0x0000    | PWM IRQ Enable Register            | Yes        | Yes       | Yes        | Yes          |
| PISR          | 0x0004    | PWM IRQ Status Register            | Yes        | Yes       | Yes        | Yes          |
| CIER          | 0x0010    | Capture IRQ Enable Register        | Yes        | Yes       | Yes        | Yes          |
| CISR          | 0x0014    | Capture IRQ Status Register        | Yes        | Yes       | Yes        | Yes          |
| PCCR01        | 0x0020    | PWM01 Clock Configuration Register | Yes        | Yes       | Yes        | Yes          |
| PCCR23        | 0x0024    | PWM23 Clock Configuration Register | Yes        | Yes       | No         | Yes          |
| PCCR45        | 0x0028    | PWM45 Clock Configuration Register | Yes        | No        | No         | Yes          |
| PCCR67        | 0x002C    | PWM67 Clock Configuration Register | Yes        | No        | No         | Yes          |
| PCCR89        | 0x0030    | PWM89 Clock Configuration Register | Yes        | No        | No         | No           |
| PCCRab        | 0x0034    | PWMab Clock Configuration Register | Yes        | No        | No         | No           |
| PCCRcd        | 0x0038    | PWMcd Clock Configuration Register | Yes        | No        | No         | No           |
| PCCRef        | 0x003C    | PWMef Clock Configuration Register | Yes        | No        | No         | No           |
| PCGR          | 0x0040    | PWM Clock Gating Register          | Yes        | Yes       | Yes        | Yes          |
| PDZCR01       | 0x0060    | PWM01 Dead Zone Control Register   | Yes        | Yes       | Yes        | Yes          |
| PDZCR23       | 0x0064    | PWM23 Dead Zone Control Register   | Yes        | Yes       | No         | Yes          |
| PDZCR45       | 0x0068    | PWM45 Dead Zone Control Register   | Yes        | No        | No         | Yes          |
| PDZCR67       | 0x006C    | PWM67 Dead Zone Control Register   | Yes        | No        | No         | Yes          |
| PDZCR89       | 0x0070    | PWM89 Dead Zone Control Register   | Yes        | No        | No         | No           |
| PDZCRab       | 0x0074    | PWMab Dead Zone Control Register   | Yes        | No        | No         | No           |
| PDZCRcd       | 0x0078    | PWMcd Dead Zone Control Register   | Yes        | No        | No         | No           |
| PDZCRef       | 0x007C    | PWMef Dead Zone Control Register   | Yes        | No        | No         | No           |
| PER           | 0x0080    | PWM Enable Register                | Yes        | Yes       | Yes        | Yes          |
| PGR0          | 0x0090    | PWM Group0 Register                | Yes        | Yes       | Yes        | Yes          |
| PGR1          | 0x0094    | PWM Group1 Register                | Yes        | Yes       | Yes        | Yes          |
| PGR2          | 0x0098    | PWM Group2 Register                | Yes        | Yes       | Yes        | Yes          |
| PGR3          | 0x009C    | PWM Group3 Register                | Yes        | Yes       | Yes        | Yes          |
| CER           | 0x00c0    | Capture Enable Register            | Yes        | Yes       | Yes        | Yes          |
| PCR           | 0x0100+N* | PWM Control Register               | N= 0 to 15 | N= 0 to 3 | N= 0, 1    | N= 0 to 7    |
| PPR           | 0x0104+N* | PWM Period Register                | N= 0 to 15 | N= 0 to 3 | N= 0, 1    | N= 0 to 7    |
| PCNTR         | 0x0108+N* | PWM Counter Register               | N= 0       | N= 0 to   | N= 0, 1    | N= 0 to 7    |

| Register Name | Offset              | Description                | PWMCTRL0   | PMWCTRL1  | S_PWMCTRL | MCU_PWMCTRL |
|---------------|---------------------|----------------------------|------------|-----------|-----------|-------------|
|               | 0x0020              |                            | to 15      | 3         |           |             |
| PPCNTR        | 0x010C+N*<br>0x0020 | PWM Pulse Counter Register | N= 0 to 15 | N= 0 to 3 | N= 0, 1   | N= 0 to 7   |
| CCR           | 0x0110+N*<br>0x0020 | Capture Control Register   | N= 0 to 15 | N= 0 to 3 | N= 0, 1   | N= 0 to 7   |
| CRLR          | 0x0114+N*<br>0x0020 | Capture Rise Lock Register | N= 0 to 15 | N= 0 to 3 | N= 0, 1   | N= 0 to 7   |
| CFLR          | 0x0118+N*<br>0x0020 | Capture Fall Lock Register | N= 0 to 15 | N= 0 to 3 | N= 0, 1   | N= 0 to 7   |

## 8.14.6 Register Description

### 8.14.6.1 0x0000 PWM IRQ Enable Register (Default Value: 0x0000\_0000)



#### NOTE

For PWMCTRL1, bit [15:4] are reserved.

For S\_PWMCTRL, bit [15:2] are reserved.

For MCU\_PWMCTRL, bit [15:8] are reserved.

| Offset:0x0000 |            |             | Register Name: PIER                                              |
|---------------|------------|-------------|------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                      |
| 31:20         | /          | /           | /                                                                |
| 19            | R/W        | 0x0         | PGIE3<br>PWM group 3 Interrupt Enable<br>0: Disable<br>1: Enable |
| 18            | R/W        | 0x0         | PGIE2<br>PWM group 2 Interrupt Enable<br>0: Disable<br>1: Enable |
| 17            | R/W        | 0x0         | PGIE1<br>PWM group 1 Interrupt Enable<br>0: Disable<br>1: Enable |
| 16            | R/W        | 0x0         | PGIE0<br>PWM group 0 Interrupt Enable<br>0: Disable<br>1: Enable |

| Offset:0x0000 |            |             | Register Name: PIER                                                                                                        |
|---------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                                |
| 15            | R/W        | 0x0         | PCIE15.<br>PWM channel 15 Interrupt Enable.<br>0: PWM channel 15 Interrupt Disable;<br>1: PWM channel 15 Interrupt Enable. |
| 14            | R/W        | 0x0         | PCIE14.<br>PWM channel 14 Interrupt Enable.<br>0: PWM channel 14 Interrupt Disable;<br>1: PWM channel 14 Interrupt Enable. |
| 13            | R/W        | 0x0         | PCIE13.<br>PWM channel 13 Interrupt Enable.<br>0: PWM channel 13 Interrupt Disable;<br>1: PWM channel 13 Interrupt Enable. |
| 12            | R/W        | 0x0         | PCIE12.<br>PWM channel 12 Interrupt Enable.<br>0: PWM channel 12 Interrupt Disable;<br>1: PWM channel 12 Interrupt Enable. |
| 11            | R/W        | 0x0         | PCIE11.<br>PWM channel 11 Interrupt Enable.<br>0: PWM channel 11 Interrupt Disable;<br>1: PWM channel 11 Interrupt Enable. |
| 10            | R/W        | 0x0         | PCIE10.<br>PWM channel 10 Interrupt Enable.<br>0: PWM channel 10 Interrupt Disable;<br>1: PWM channel 10 Interrupt Enable. |
| 9             | R/W        | 0x0         | PCIE9.<br>PWM channel 9 Interrupt Enable.<br>0: PWM channel 9 Interrupt Disable;<br>1: PWM channel 9 Interrupt Enable.     |
| 8             | R/W        | 0x0         | PCIE8.<br>PWM channel 8 Interrupt Enable.<br>0: PWM channel 8 Interrupt Disable;<br>1: PWM channel 8 Interrupt Enable.     |
| 7             | R/W        | 0x0         | PCIE7.<br>PWM channel 7 Interrupt Enable.<br>0: PWM channel 7 Interrupt Disable;<br>1: PWM channel 7 Interrupt Enable.     |
| 6             | R/W        | 0x0         | PCIE6.<br>PWM channel 6 Interrupt Enable.<br>0: PWM channel 6 Interrupt Disable;<br>1: PWM channel 6 Interrupt Enable.     |
| 5             | R/W        | 0x0         | PCIE5.                                                                                                                     |

| Offset:0x0000 |            |             | Register Name: PIER                                                                                                    |
|---------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------|
| Bit           | Read/Write | Default/Hex | Description                                                                                                            |
|               |            |             | PWM channel 5 Interrupt Enable.<br>0: PWM channel 5 Interrupt Disable;<br>1: PWM channel 5 Interrupt Enable.           |
| 4             | R/W        | 0x0         | PCIE4.<br>PWM channel 4 Interrupt Enable.<br>0: PWM channel 4 Interrupt Disable;<br>1: PWM channel 4 Interrupt Enable. |
| 3             | R/W        | 0x0         | PCIE3.<br>PWM channel 3 Interrupt Enable.<br>0: PWM channel 3 Interrupt Disable;<br>1: PWM channel 3 Interrupt Enable. |
| 2             | R/W        | 0x0         | PCIE2.<br>PWM channel 2 Interrupt Enable.<br>0: PWM channel 2 Interrupt Disable;<br>1: PWM channel 2 Interrupt Enable. |
| 1             | R/W        | 0x0         | PCIE1.<br>PWM channel 1 Interrupt Enable.<br>0: PWM channel 1 Interrupt Disable;<br>1: PWM channel 1 Interrupt Enable. |
| 0             | R/W        | 0x0         | PCIE0.<br>PWM channel 0 Interrupt Enable.<br>0: PWM channel 0 Interrupt Disable;<br>1: PWM channel 0 Interrupt Enable. |

#### 8.14.6.2 0x0004 PWM IRQ Status Register (Default Value: 0x0000\_0000)



##### NOTE

For PWMCTRL1, bit [15:4] are reserved.

For S\_PWMCTRL, bit [15:2] are reserved.

For MCU\_PWWMCTRL, bit [15:8] are reserved.

| Offset: 0x0004 |            |             | Register Name: PISR                   |
|----------------|------------|-------------|---------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                           |
| 31:20          | /          | /           | /                                     |
| 19             | R/W1C      | 0x0         | PGIS3<br>PWM group 3 Interrupt Status |
| 18             | R/W1C      | 0x0         | PGIS2<br>PWM group 2 Interrupt Status |

| Offset: 0x0004 |            |             | Register Name: PISR                                                                                                                                                                                                                                                                                                               |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                       |
| 17             | R/W1C      | 0x0         | PGIS1<br>PWM group 1 Interrupt Status                                                                                                                                                                                                                                                                                             |
| 16             | R/W1C      | 0x0         | PGIS0<br>PWM group 0 Interrupt Status                                                                                                                                                                                                                                                                                             |
| 15             | R/W1C      | 0x0         | PIS15.<br>PWM channel 15 Interrupt Status. When PWM channel 15 counter reaches Entire Cycle Value, this bit is set 1 by hardware. Write 1 to clear this bit.<br>Reads 0: PWM channel 15 interrupt is not pending.<br>1: PWM channel 15 interrupt is pending.<br>Writes 0: no effect.<br>1: Clear PWM channel 15 interrupt status. |
| 14             | R/W1C      | 0x0         | PIS14.<br>PWM channel 14 Interrupt Status. When PWM channel 14 counter reaches Entire Cycle Value, this bit is set 1 by hardware. Write 1 to clear this bit.<br>Reads 0: PWM channel 14 interrupt is not pending.<br>1: PWM channel 14 interrupt is pending.<br>Writes 0: no effect.<br>1: Clear PWM channel 14 interrupt status. |
| 13             | R/W1C      | 0x0         | PIS13.<br>PWM channel 13 Interrupt Status. When PWM channel 13 counter reaches Entire Cycle Value, this bit is set 1 by hardware. Write 1 to clear this bit.<br>Reads 0: PWM channel 13 interrupt is not pending.<br>1: PWM channel 13 interrupt is pending.<br>Writes 0: no effect.<br>1: Clear PWM channel 13 interrupt status. |
| 12             | R/W1C      | 0x0         | PIS12.<br>PWM channel 12 Interrupt Status. When PWM channel 12 counter reaches Entire Cycle Value, this bit is set 1 by hardware. Write 1 to clear this bit.<br>Reads 0: PWM channel 12 interrupt is not pending.                                                                                                                 |

| Offset: 0x0004 |            |             | Register Name: PISR                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                               |
|                |            |             | <p>1: PWM channel 12 interrupt is pending.<br/>Writes 0: no effect.</p> <p>1: Clear PWM channel 12 interrupt status.</p>                                                                                                                                                                                                                                  |
| 11             | R/W1C      | 0x0         | <p>PIS11.</p> <p>PWM channel 11 Interrupt Status. When PWM channel 11 counter reaches Entire Cycle Value, this bit is set 1 by hardware. Write 1 to clear this bit.</p> <p>Reads 0: PWM channel 11 interrupt is not pending.</p> <p>1: PWM channel 11 interrupt is pending.<br/>Writes 0: no effect.</p> <p>1: Clear PWM channel 11 interrupt status.</p> |
| 10             | R/W1C      | 0x0         | <p>PIS10.</p> <p>PWM channel 10 Interrupt Status. When PWM channel 10 counter reaches Entire Cycle Value, this bit is set 1 by hardware. Write 1 to clear this bit.</p> <p>Reads 0: PWM channel 10 interrupt is not pending.</p> <p>1: PWM channel 10 interrupt is pending.<br/>Writes 0: no effect.</p> <p>1: Clear PWM channel 10 interrupt status.</p> |
| 9              | R/W1C      | 0x0         | <p>PIS9.</p> <p>PWM channel 9 Interrupt Status. When PWM channel 9 counter reaches Entire Cycle Value, this bit is set 1 by hardware. Write 1 to clear this bit.</p> <p>Reads 0: PWM channel 9 interrupt is not pending.</p> <p>1: PWM channel 9 interrupt is pending.<br/>Writes 0: no effect.</p> <p>1: Clear PWM channel 9 interrupt status.</p>       |
| 8              | R/W1C      | 0x0         | <p>PIS8.</p> <p>PWM channel 8 Interrupt Status. When PWM channel 8 counter reaches Entire Cycle Value, this bit is set 1 by hardware. Write 1 to clear this bit.</p> <p>Reads 0: PWM channel 8 interrupt is not pending.</p> <p>1: PWM channel 8 interrupt is pending.</p>                                                                                |

| Offset: 0x0004 |            |             | Register Name: PISR                                                                                                                                                                                                                                                                                                         |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                 |
|                |            |             | Writes 0: no effect.<br>1: Clear PWM channel 8 interrupt status.                                                                                                                                                                                                                                                            |
| 7              | R/W1C      | 0x0         | PIS7.<br>PWM channel 7 Interrupt Status. When PWM channel 7 counter reaches Entire Cycle Value, this bit is set 1 by hardware. Write 1 to clear this bit.<br>Reads 0: PWM channel 7 interrupt is not pending.<br>1: PWM channel 7 interrupt is pending.<br>Writes 0: no effect.<br>1: Clear PWM channel 7 interrupt status. |
| 6              | R/W1C      | 0x0         | PIS6.<br>PWM channel 6 Interrupt Status. When PWM channel 6 counter reaches Entire Cycle Value, this bit is set 1 by hardware. Write 1 to clear this bit.<br>Reads 0: PWM channel 6 interrupt is not pending.<br>1: PWM channel 6 interrupt is pending.<br>Writes 0: no effect.<br>1: Clear PWM channel 6 interrupt status. |
| 5              | R/W1C      | 0x0         | PIS5.<br>PWM channel 5 Interrupt Status. When PWM channel 5 counter reaches Entire Cycle Value, this bit is set 1 by hardware. Write 1 to clear this bit.<br>Reads 0: PWM channel 5 interrupt is not pending.<br>1: PWM channel 5 interrupt is pending.<br>Writes 0: no effect.<br>1: Clear PWM channel 5 interrupt status. |
| 4              | R/W1C      | 0x0         | PIS4.<br>PWM channel 4 Interrupt Status. When PWM channel 4 counter reaches Entire Cycle Value, this bit is set 1 by hardware. Write 1 to clear this bit.<br>Reads 0: PWM channel 4 interrupt is not pending.<br>1: PWM channel 4 interrupt is pending.<br>Writes 0: no effect.                                             |

| Offset: 0x0004 |            |             | Register Name: PISR                                                                                                                                                                                                                                                                                                                     |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                             |
|                |            |             | <p>1: Clear PWM channel 4 interrupt status.</p>                                                                                                                                                                                                                                                                                         |
| 3              | R/W1C      | 0x0         | <p>PIS3.<br/>PWM channel 3 Interrupt Status. When PWM channel 3 counter reaches Entire Cycle Value, this bit is set 1 by hardware. Write 1 to clear this bit.<br/>Reads 0: PWM channel 3 interrupt is not pending.<br/>1: PWM channel 3 interrupt is pending.<br/>Writes 0: no effect.<br/>1: Clear PWM channel 3 interrupt status.</p> |
| 2              | R/W1C      | 0x0         | <p>PIS2.<br/>PWM channel 2 Interrupt Status. When PWM channel 2 counter reaches Entire Cycle Value, this bit is set 1 by hardware. Write 1 to clear this bit.<br/>Reads 0: PWM channel 2 interrupt is not pending.<br/>1: PWM channel 2 interrupt is pending.<br/>Writes 0: no effect.<br/>1: Clear PWM channel 2 interrupt status.</p> |
| 1              | R/W1C      | 0x0         | <p>PIS1.<br/>PWM channel 1 Interrupt Status. When PWM channel 1 counter reaches Entire Cycle Value, this bit is set 1 by hardware. Write 1 to clear this bit.<br/>Reads 0: PWM channel 1 interrupt is not pending.<br/>1: PWM channel 1 interrupt is pending.<br/>Writes 0: no effect.<br/>1: Clear PWM channel 1 interrupt status.</p> |
| 0              | R/W1C      | 0x0         | <p>PIS0.<br/>PWM channel 0 Interrupt Status. When PWM channel 0 counter reaches Entire Cycle Value, this bit is set 1 by hardware. Write 1 to clear this bit.<br/>Reads 0: PWM channel 0 interrupt is not pending.<br/>1: PWM channel 0 interrupt is pending.<br/>Writes 0: no effect.<br/>1: Clear PWM channel 0 interrupt status.</p> |

## 8.14.6.3 0x0010 Capture IRQ Enable Register (Default Value: 0x0000\_0000)



For PWMCTRL1, bit [31:8] are reserved.

For S\_PWMCTRL, bit [31:4] are reserved.

For MCU\_PWWMCTRL, bit [31:16] are reserved.

| Offset: 0x0010 |            |             | Register Name: CIER                                                                                                                                                                                                                         |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                 |
| 31             | R/W        | 0x0         | CFIE15<br>If this enable bit is set 1, when capture channel 15 captures falling edge, it generates a capture channel 15 pending.<br>0: Capture channel 15 fall lock Interrupt disable;<br>1: Capture channel 15 fall lock Interrupt enable. |
| 30             | R/W        | 0x0         | CRIE15<br>If this enable bit is set 1, when capture channel 15 captures rising edge, it generates a capture channel 15 pending.<br>0: Capture channel 15 rise lock Interrupt disable;<br>1: Capture channel 15 rise lock Interrupt enable.  |
| 29             | R/W        | 0x0         | CFIE14<br>If this enable bit is set 1, when capture channel 14 captures falling edge, it generates a capture channel 14 pending.<br>0: Capture channel 14 fall lock Interrupt disable;<br>1: Capture channel 14 fall lock Interrupt enable. |
| 28             | R/W        | 0x0         | CRIE14<br>If this enable bit is set 1, when capture channel 14 captures rising edge, it generates a capture channel 14 pending.<br>0: Capture channel 14 rise lock Interrupt disable;<br>1: Capture channel 14 rise lock Interrupt enable.  |
| 27             | R/W        | 0x0         | CFIE13<br>If this enable bit is set 1, when capture channel 13 captures falling edge, it generates a capture channel 13 pending.<br>0: Capture channel 13 fall lock Interrupt disable;<br>1: Capture channel 13 fall lock Interrupt enable. |
| 26             | R/W        | 0x0         | CRIE13<br>If this enable bit is set 1, when capture channel                                                                                                                                                                                 |

| Offset: 0x0010 |            |             | Register Name: CIER                                                                                                                                                                                                                         |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                 |
|                |            |             | 13 captures rising edge, it generates a capture channel 13 pending.<br>0: Capture channel 13 rise lock Interrupt disable;<br>1: Capture channel 13 rise lock Interrupt enable.                                                              |
| 25             | R/W        | 0x0         | CFIE12<br>If this enable bit is set 1, when capture channel 12 captures falling edge, it generates a capture channel 12 pending.<br>0: Capture channel 12 fall lock Interrupt disable;<br>1: Capture channel 12 fall lock Interrupt enable. |
| 24             | R/W        | 0x0         | CRIE12<br>If this enable bit is set 1, when capture channel 12 captures rising edge, it generates a capture channel 12 pending.<br>0: Capture channel 12 rise lock Interrupt disable;<br>1: Capture channel 12 rise lock Interrupt enable.  |
| 23             | R/W        | 0x0         | CFIE11<br>If this enable bit is set 1, when capture channel 11 captures falling edge, it generates a capture channel 11 pending.<br>0: Capture channel 11 fall lock Interrupt disable;<br>1: Capture channel 11 fall lock Interrupt enable. |
| 22             | R/W        | 0x0         | CRIE11<br>If this enable bit is set 1, when capture channel 11 captures rising edge, it generates a capture channel 11 pending.<br>0: Capture channel 11 rise lock Interrupt disable;<br>1: Capture channel 11 rise lock Interrupt enable.  |
| 21             | R/W        | 0x0         | CFIE10<br>If this enable bit is set 1, when capture channel 10 captures falling edge, it generates a capture channel 10 pending.<br>0: Capture channel 10 fall lock Interrupt disable;<br>1: Capture channel 10 fall lock Interrupt enable. |
| 20             | R/W        | 0x0         | CRIE10<br>If this enable bit is set 1, when capture channel 10 captures rising edge, it generates a capture channel 10 pending.<br>0: Capture channel 10 rise lock Interrupt disable;<br>1: Capture channel 10 rise lock Interrupt enable.  |
| 19             | R/W        | 0x0         | CFIE9                                                                                                                                                                                                                                       |

| Offset: 0x0010 |            |             | Register Name: CIER                                                                                                                                                                                                                    |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                            |
|                |            |             | If this enable bit is set 1, when capture channel 9 captures falling edge, it generates a capture channel 9 pending.<br>0: Capture channel 9 fall lock Interrupt disable;<br>1: Capture channel 9 fall lock Interrupt enable.          |
| 18             | R/W        | 0x0         | CRIE9<br>If this enable bit is set 1, when capture channel 9 captures rising edge, it generates a capture channel 9 pending.<br>0: Capture channel 9 rise lock Interrupt disable;<br>1: Capture channel 9 rise lock Interrupt enable.  |
| 17             | R/W        | 0x0         | CFIE8<br>If this enable bit is set 1, when capture channel 8 captures falling edge, it generates a capture channel 8 pending.<br>0: Capture channel 8 fall lock Interrupt disable;<br>1: Capture channel 8 fall lock Interrupt enable. |
| 16             | R/W        | 0x0         | CRIE8<br>If this enable bit is set 1, when capture channel 8 captures rising edge, it generates a capture channel 8 pending.<br>0: Capture channel 8 rise lock Interrupt disable;<br>1: Capture channel 8 rise lock Interrupt enable.  |
| 15             | R/W        | 0x0         | CFIE7<br>If this enable bit is set 1, when capture channel 7 captures falling edge, it generates a capture channel 7 pending.<br>0: Capture channel 7 fall lock Interrupt disable;<br>1: Capture channel 7 fall lock Interrupt enable. |
| 14             | R/W        | 0x0         | CRIE7<br>If this enable bit is set 1, when capture channel 7 captures rising edge, it generates a capture channel 7 pending.<br>0: Capture channel 7 rise lock Interrupt disable;<br>1: Capture channel 7 rise lock Interrupt enable.  |
| 13             | R/W        | 0x0         | CFIE6<br>If this enable bit is set 1, when capture channel 6 captures falling edge, it generates a capture channel 6 pending.<br>0: Capture channel 6 fall lock Interrupt disable;<br>1: Capture channel 6 fall lock Interrupt enable. |

| Offset: 0x0010 |            |             | Register Name: CIER                                                                                                                                                                                                                    |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                            |
| 12             | R/W        | 0x0         | CRIE6<br>If this enable bit is set 1, when capture channel 5 captures rising edge, it generates a capture channel 5 pending.<br>0: Capture channel 5 rise lock Interrupt disable;<br>1: Capture channel 5 rise lock Interrupt enable.  |
| 11             | R/W        | 0x0         | CFIE5<br>If this enable bit is set 1, when capture channel 5 captures falling edge, it generates a capture channel 5 pending.<br>0: Capture channel 5 fall lock Interrupt disable;<br>1: Capture channel 5 fall lock Interrupt enable. |
| 10             | R/W        | 0x0         | CRIE5<br>If this enable bit is set 1, when capture channel 5 captures rising edge, it generates a capture channel 5 pending.<br>0: Capture channel 5 rise lock Interrupt disable;<br>1: Capture channel 5 rise lock Interrupt enable.  |
| 9              | R/W        | 0x0         | CFIE4<br>If this enable bit is set 1, when capture channel 4 captures falling edge, it generates a capture channel 4 pending.<br>0: Capture channel 4 fall lock Interrupt disable;<br>1: Capture channel 4 fall lock Interrupt enable. |
| 8              | R/W        | 0x0         | CRIE4<br>If this enable bit is set 1, when capture channel 4 captures rising edge, it generates a capture channel 4 pending.<br>0: Capture channel 4 rise lock Interrupt disable;<br>1: Capture channel 4 rise lock Interrupt enable.  |
| 7              | R/W        | 0x0         | CFIE3<br>If this enable bit is set 1, when capture channel 3 captures falling edge, it generates a capture channel 3 pending.<br>0: Capture channel 3 fall lock Interrupt disable;<br>1: Capture channel 3 fall lock Interrupt enable. |
| 6              | R/W        | 0x0         | CRIE3<br>If this enable bit is set 1, when capture channel 3 captures rising edge, it generates a capture channel 3 pending.<br>0: Capture channel 3 rise lock Interrupt disable;                                                      |

| Offset: 0x0010 |            |             | Register Name: CIER                                                                                                                                                                                                                    |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                            |
|                |            |             | 1: Capture channel 3 rise lock Interrupt enable.                                                                                                                                                                                       |
| 5              | R/W        | 0x0         | CFIE2<br>If this enable bit is set 1, when capture channel 2 captures falling edge, it generates a capture channel 2 pending.<br>0: Capture channel 2 fall lock Interrupt disable;<br>1: Capture channel 2 fall lock Interrupt enable. |
| 4              | R/W        | 0x0         | CRIE2<br>If this enable bit is set 1, when capture channel 2 captures rising edge, it generates a capture channel 2 pending.<br>0: Capture channel 2 rise lock Interrupt disable;<br>1: Capture channel 2 rise lock Interrupt enable.  |
| 3              | R/W        | 0x0         | CFIE1<br>If this enable bit is set 1, when capture channel 1 captures falling edge, it generates a capture channel 1 pending.<br>0: Capture channel 1 fall lock Interrupt disable;<br>1: Capture channel 1 fall lock Interrupt enable. |
| 2              | R/W        | 0x0         | CRIE1<br>If this enable bit is set 1, when capture channel 1 captures rising edge, it generates a capture channel 1 pending.<br>0: Capture channel 1 rise lock Interrupt disable;<br>1: Capture channel 1 rise lock Interrupt enable.  |
| 1              | R/W        | 0x0         | CFIE0<br>If this enable bit is set 1, when capture channel 0 captures falling edge, it generates a capture channel 0 pending.<br>0: Capture channel 0 fall lock Interrupt disable;<br>1: Capture channel 0 fall lock Interrupt enable. |
| 0              | R/W        | 0x0         | CRIE0<br>If this enable bit is set 1, when capture channel 0 captures rising edge, it generates a capture channel 0 pending<br>0: Capture channel 0 rise lock Interrupt disable;<br>1: Capture channel 0 rise lock Interrupt enable.   |

## 8.14.6.4 0x0014 Capture IRQ Status Register (Default Value: 0x0000\_0000)



## NOTE

For PWMCTRL1, bit [31:8] are reserved.

For S\_PWMCTRL, bit [31:4] are reserved.

For MCU\_PWWMCTRL, bit [31:16] are reserved.

| Offset: 0x0014 |            |             | Register Name: CISR                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 31             | R/W1C      | 0x0         | <p>CFIS15<br/>Capture channel 15 falling lock interrupt status.<br/>When capture channel 15 captures falling edge, if capture channel 15 fall lock interrupt (CFIE15) is enabled, this bit is set 1 by hardware.<br/>Write 1 to clear this bit.<br/>Reads 0: Capture channel 15 interrupt is not pending.<br/>1: Capture channel 15 interrupt is pending.<br/>Writes 0: no effect.<br/>1: Clear capture channel 15 interrupt status.</p> |
| 30             | R/W1C      | 0x0         | <p>CRIS15<br/>Capture channel 15 rising lock interrupt status.<br/>When capture channel 15 captures rising edge, if capture channel 15 rise lock interrupt (CRIE15) is enabled, this bit is set 1 by hardware.<br/>Write 1 to clear this bit.<br/>Reads 0: Capture channel 15 interrupt is not pending.<br/>1: Capture channel 15 interrupt is pending.<br/>Writes 0: no effect.<br/>1: Clear capture channel 15 interrupt status.</p>   |
| 29             | R/W1C      | 0x0         | <p>CFIS14<br/>Capture channel 14 falling lock interrupt status<br/>When capture channel 14 captures falling edge, if capture channel 14 fall lock interrupt (CFIE14) is enabled, this bit is set 1 by hardware.<br/>Write 1 to clear this bit.</p>                                                                                                                                                                                       |

| Offset: 0x0014 |            |             | Register Name: CISR                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                |            |             | <p>Reads 0: Capture channel 14 interrupt is not pending.<br/> 1: Capture channel 14 interrupt is pending.<br/> Writes 0: no effect.<br/> 1: Clear capture channel 14 interrupt status.</p>                                                                                                                                                                                                                                                     |
| 28             | R/W1C      | 0x0         | <p>CRIS14<br/> Capture channel 14 rising lock interrupt status<br/> When capture channel 14 captures rising edge, if capture channel 14 rise lock interrupt (CRIE14) is enabled, this bit is set 1 by hardware.<br/> Write 1 to clear this bit.<br/> Reads 0: Capture channel 14 interrupt is not pending.<br/> 1: Capture channel 14 interrupt is pending.<br/> Writes 0: no effect.<br/> 1: Clear capture channel 14 interrupt status.</p>   |
| 27             | R/W1C      | 0x0         | <p>CFIS13<br/> Capture channel 13 falling lock interrupt status<br/> When capture channel 13 captures falling edge, if capture channel 13 fall lock interrupt (CFIE13) is enabled, this bit is set 1 by hardware.<br/> Write 1 to clear this bit.<br/> Reads 0: Capture channel 13 interrupt is not pending.<br/> 1: Capture channel 13 interrupt is pending.<br/> Writes 0: no effect.<br/> 1: Clear capture channel 13 interrupt status.</p> |
| 26             | R/W1C      | 0x0         | <p>CRIS13<br/> Capture channel 13 rising lock interrupt status<br/> When capture channel 13 captures rising edge, if capture channel 13 rise lock interrupt (CRIE13) is enabled, this bit is set 1 by hardware.<br/> Write 1 to clear this bit.<br/> Reads 0: Capture channel 13 interrupt is not pending.</p>                                                                                                                                 |

| Offset: 0x0014 |            |             | Register Name: CISR                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                |            |             | <p>1: Capture channel 13 interrupt is pending.<br/>Writes 0: no effect.</p> <p>1: Clear capture channel 13 interrupt status.</p>                                                                                                                                                                                                                                                                                                                 |
| 25             | R/W1C      | 0x0         | <p>CFIS12<br/>Capture channel 12 falling lock interrupt status<br/>When capture channel 12 captures falling edge, if capture channel 12 fall lock interrupt (CFIE12) is enabled, this bit is set 1 by hardware.<br/>Write 1 to clear this bit.</p> <p>Reads 0: Capture channel 12 interrupt is not pending.</p> <p>1: Capture channel 12 interrupt is pending.<br/>Writes 0: no effect.</p> <p>1: Clear capture channel 12 interrupt status.</p> |
| 24             | R/W1C      | 0x0         | <p>CRIS12<br/>Capture channel 12 rising lock interrupt status<br/>When capture channel 12 captures rising edge, if capture channel 12 rise lock interrupt (CRIE12) is enabled, this bit is set 1 by hardware.<br/>Write 1 to clear this bit.</p> <p>Reads 0: Capture channel 12 interrupt is not pending.</p> <p>1: Capture channel 12 interrupt is pending.<br/>Writes 0: no effect.</p> <p>1: Clear capture channel 12 interrupt status.</p>   |
| 23             | R/W1C      | 0x0         | <p>CFIS11<br/>Capture channel 11 falling lock interrupt status<br/>When capture channel 11 captures falling edge, if capture channel 11 fall lock interrupt (CFIE11) is enabled, this bit is set 1 by hardware.<br/>Write 1 to clear this bit.</p> <p>Reads 0: Capture channel 11 interrupt is not pending.</p> <p>1: Capture channel 11 interrupt is pending.</p>                                                                               |

| Offset: 0x0014 |            |             | Register Name: CISR                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                |            |             | <p>Writes 0: no effect.</p> <p>1: Clear capture channel 11 interrupt status.</p>                                                                                                                                                                                                                                                                                                                                                                             |
| 22             | R/W1C      | 0x0         | <p>CRIS11</p> <p>Capture channel 11 rising lock interrupt status.</p> <p>When capture channel 11 captures rising edge, if capture channel 11 rise lock interrupt (CRIE11) is enabled, this bit is set 1 by hardware.</p> <p>Write 1 to clear this bit.</p> <p>Reads 0: Capture channel 11 interrupt is not pending.</p> <p>1: Capture channel 11 interrupt is pending.</p> <p>Writes 0: no effect.</p> <p>1: Clear capture channel 11 interrupt status.</p>  |
| 21             | R/W1C      | 0x0         | <p>CFIS10</p> <p>Capture channel 10 falling lock interrupt status</p> <p>When capture channel 10 captures falling edge, if capture channel 10 fall lock interrupt (CFIE10) is enabled, this bit is set 1 by hardware.</p> <p>Write 1 to clear this bit.</p> <p>Reads 0: Capture channel 10 interrupt is not pending.</p> <p>1: Capture channel 10 interrupt is pending.</p> <p>Writes 0: no effect.</p> <p>1: Clear capture channel 10 interrupt status.</p> |
| 20             | R/W1C      | 0x0         | <p>CRIS10</p> <p>Capture channel 10 rising lock interrupt status</p> <p>When capture channel 10 captures rising edge, if capture channel 10 rise lock interrupt (CRIE10) is enabled, this bit is set 1 by hardware.</p> <p>Write 1 to clear this bit.</p> <p>Reads 0: Capture channel 10 interrupt is not pending.</p> <p>1: Capture channel 10 interrupt is pending.</p> <p>Writes 0: no effect.</p> <p>1: Clear capture channel 10 interrupt</p>           |

| Offset: 0x0014 |            |             | Register Name: CISR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                |            |             | status.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 19             | R/W1C      | 0x0         | <p>CFIS9<br/>                     Capture channel 9 falling lock interrupt status<br/>                     When capture channel 9 captures falling edge, if capture channel 9 fall lock interrupt (CFIE9) is enabled, this bit is set 1 by hardware.<br/>                     Write 1 to clear this bit.<br/>                     Reads 0: Capture channel 9 interrupt is not pending.<br/>                         1: Capture channel 9 interrupt is pending.<br/>                     Writes 0: no effect.<br/>                         1: Clear capture channel 9 interrupt status.</p> |
| 18             | R/W1C      | 0x0         | <p>CRIS9<br/>                     Capture channel 9 rising lock interrupt status<br/>                     When capture channel 9 captures rising edge, if capture channel 9 rise lock interrupt (CRIE9) is enabled, this bit is set 1 by hardware.<br/>                     Write 1 to clear this bit.<br/>                     Reads 0: Capture channel 9 interrupt is not pending.<br/>                         1: Capture channel 9 interrupt is pending.<br/>                     Writes 0: no effect.<br/>                         1: Clear capture channel 9 interrupt status.</p>   |
| 17             | R/W1C      | 0x0         | <p>CFIS8<br/>                     Capture channel 8 falling lock interrupt status<br/>                     When capture channel 8 captures falling edge, if capture channel 8 fall lock interrupt (CFIE8) is enabled, this bit is set 1 by hardware.<br/>                     Write 1 to clear this bit.<br/>                     Reads 0: Capture channel 8 interrupt is not pending.<br/>                         1: Capture channel 8 interrupt is pending.<br/>                     Writes 0: no effect.<br/>                         1: Clear capture channel 8 interrupt status.</p> |
| 16             | R/W1C      | 0x0         | <p>CRIS8<br/>                     Capture channel 8 rising lock interrupt status<br/>                     When capture channel 8 captures rising edge, if capture channel 8 rise lock interrupt (CRIE8) is</p>                                                                                                                                                                                                                                                                                                                                                                             |

| Offset: 0x0014 |            |             | Register Name: CISR                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                |            |             | <p>enabled, this bit is set 1 by hardware.<br/>       Write 1 to clear this bit.</p> <p>Reads 0: Capture channel 8 interrupt is not pending.<br/>       1: Capture channel 8 interrupt is pending.<br/>       Writes 0: no effect.<br/>       1: Clear capture channel 8 interrupt status.</p>                                                                                                                                                                                   |
| 15             | R/W1C      | 0x0         | <p>CFIS7<br/>       Capture channel 7 falling lock interrupt status<br/>       When capture channel 7 captures falling edge, if capture channel 7 fall lock interrupt (CFIE7) is enabled, this bit is set 1 by hardware.<br/>       Write 1 to clear this bit.<br/>       Reads 0: Capture channel 7 interrupt is not pending.<br/>       1: Capture channel 7 interrupt is pending.<br/>       Writes 0: no effect.<br/>       1: Clear capture channel 7 interrupt status.</p> |
| 14             | R/W1C      | 0x0         | <p>CRIS7<br/>       Capture channel 7 rising lock interrupt status<br/>       When capture channel 7 captures rising edge, if capture channel 7 rise lock interrupt (CRIE7) is enabled, this bit is set 1 by hardware.<br/>       Write 1 to clear this bit.<br/>       Reads 0: Capture channel 7 interrupt is not pending.<br/>       1: Capture channel 7 interrupt is pending.<br/>       Writes 0: no effect.<br/>       1: Clear capture channel 7 interrupt status.</p>   |
| 13             | R/W1C      | 0x0         | <p>CFIS6<br/>       Capture channel 6 falling lock interrupt status<br/>       When capture channel 6 captures falling edge, if capture channel 6 fall lock interrupt (CFIE6) is enabled, this bit is set 1 by hardware.<br/>       Write 1 to clear this bit.<br/>       Reads 0: Capture channel 6 interrupt is not pending.<br/>       1: Capture channel 6 interrupt is pending.</p>                                                                                         |

| Offset: 0x0014 |            |             | Register Name: CISR                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                       |
|                |            |             | Writes 0: no effect.<br>1: Clear capture channel 6 interrupt status.                                                                                                                                                                                                                                                                                                                                              |
| 12             | R/W1C      | 0x0         | CRIS6<br>Capture channel 6 rising lock interrupt status<br>When capture channel 6 captures rising edge, if capture channel 6 rise lock interrupt (CRIE6) is enabled, this bit is set 1 by hardware.<br>Write 1 to clear this bit.<br>Reads 0: Capture channel 6 interrupt is not pending.<br>1: Capture channel 6 interrupt is pending.<br>Writes 0: no effect.<br>1: Clear capture channel 6 interrupt status.   |
| 11             | R/W1C      | 0x0         | CFIS5<br>Capture channel 5 falling lock interrupt status<br>When capture channel 5 captures falling edge, if capture channel 5 fall lock interrupt (CFIE5) is enabled, this bit is set 1 by hardware.<br>Write 1 to clear this bit.<br>Reads 0: Capture channel 5 interrupt is not pending.<br>1: Capture channel 5 interrupt is pending.<br>Writes 0: no effect.<br>1: Clear capture channel 5 interrupt status. |
| 10             | R/W1C      | 0x0         | CRIS5<br>Capture channel 5 rising lock interrupt status<br>When capture channel 5 captures rising edge, if capture channel 5 rise lock interrupt (CRIE5) is enabled, this bit is set 1 by hardware.<br>Write 1 to clear this bit.<br>Reads 0: Capture channel 5 interrupt is not pending.<br>1: Capture channel 5 interrupt is pending.<br>Writes 0: no effect.<br>1: Clear capture channel 5 interrupt status.   |
| 9              | R/W1C      | 0x0         | CFIS4<br>Capture channel 4 falling lock interrupt status                                                                                                                                                                                                                                                                                                                                                          |

| Offset: 0x0014 |            |             | Register Name: CISR                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                |            |             | <p>When capture channel 4 captures falling edge, if capture channel 4 fall lock interrupt (CFIE4) is enabled, this bit is set 1 by hardware.</p> <p>Write 1 to clear this bit.</p> <p>Reads 0: Capture channel 4 interrupt is not pending.</p> <p>1: Capture channel 4 interrupt is pending.</p> <p>Writes 0: no effect.</p> <p>1: Clear capture channel 4 interrupt status.</p>                                                                     |
| 8              | R/W1C      | 0x0         | <p>CRIS4</p> <p>Capture channel 4 rising lock interrupt status</p> <p>When capture channel 4 captures rising edge, if capture channel 4 rise lock interrupt (CRIE4) is enabled, this bit is set 1 by hardware.</p> <p>Write 1 to clear this bit.</p> <p>Reads 0: Capture channel 4 interrupt is not pending.</p> <p>1: Capture channel 4 interrupt is pending.</p> <p>Writes 0: no effect.</p> <p>1: Clear capture channel 4 interrupt status.</p>   |
| 7              | R/W1C      | 0x0         | <p>CFIS3</p> <p>Capture channel 3 falling lock interrupt status</p> <p>When capture channel 3 captures falling edge, if capture channel 3 fall lock interrupt (CFIE3) is enabled, this bit is set 1 by hardware.</p> <p>Write 1 to clear this bit.</p> <p>Reads 0: Capture channel 3 interrupt is not pending.</p> <p>1: Capture channel 3 interrupt is pending.</p> <p>Writes 0: no effect.</p> <p>1: Clear capture channel 3 interrupt status.</p> |
| 6              | R/W1C      | 0x0         | <p>CRIS3</p> <p>Capture channel 3 rising lock interrupt status</p> <p>When capture channel 3 captures rising edge, if capture channel 3 rise lock interrupt (CRIE3) is enabled, this bit is set 1 by hardware.</p> <p>Write 1 to clear this bit.</p> <p>Reads 0: Capture channel 3 interrupt is not</p>                                                                                                                                              |

| Offset: 0x0014 |            |             | Register Name: CISR                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                |            |             | <p>pending.</p> <p>1: Capture channel 3 interrupt is pending.<br/>Writes 0: no effect.</p> <p>1: Clear capture channel 3 interrupt status.</p>                                                                                                                                                                                                                                                                                                 |
| 5              | R/W1C      | 0x0         | <p>CFIS2</p> <p>Capture channel 2 falling lock interrupt status<br/>When capture channel 2 captures falling edge, if capture channel 2 fall lock interrupt (CFIE2) is enabled, this bit is set 1 by hardware.</p> <p>Write 1 to clear this bit.</p> <p>Reads 0: Capture channel 2 interrupt is not pending.</p> <p>1: Capture channel 2 interrupt is pending.<br/>Writes 0: no effect.</p> <p>1: Clear capture channel 2 interrupt status.</p> |
| 4              | R/W1C      | 0x0         | <p>CRIS2</p> <p>Capture channel 2 rising lock interrupt status<br/>When capture channel 2 captures rising edge, if capture channel 2 rise lock interrupt (CRIE2) is enabled, this bit is set 1 by hardware.</p> <p>Write 1 to clear this bit.</p> <p>Reads 0: Capture channel 2 interrupt is not pending.</p> <p>1: Capture channel 2 interrupt is pending.<br/>Writes 0: no effect.</p> <p>1: Clear capture channel 2 interrupt status.</p>   |
| 3              | R/W1C      | 0x0         | <p>CFIS1</p> <p>Capture channel 1 falling lock interrupt status<br/>When capture channel 1 captures falling edge, if capture channel 1 fall lock interrupt (CFIE1) is enabled, this bit is set 1 by hardware.</p> <p>Write 1 to clear this bit.</p> <p>Reads 0: Capture channel 1 interrupt is not pending.</p> <p>1: Capture channel 1 interrupt is pending.<br/>Writes 0: no effect.</p> <p>1: Clear capture channel 1 interrupt status.</p> |

| Offset: 0x0014 |            |             | Register Name: CISR                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 2              | R/W1C      | 0x0         | <p>CRIS1</p> <p>Capture channel 1 rising lock interrupt status</p> <p>When capture channel 1 captures rising edge, if capture channel 1 rise lock interrupt (CRIE1) is enabled, this bit is set 1 by hardware.</p> <p>Write 1 to clear this bit.</p> <p>Reads 0: Capture channel 1 interrupt is not pending.</p> <p>1: Capture channel 1 interrupt is pending.</p> <p>Writes 0: no effect.</p> <p>1: Clear capture channel 1 interrupt status.</p>   |
| 1              | R/W1C      | 0x0         | <p>CFIS0</p> <p>Capture channel 0 falling lock interrupt status</p> <p>When capture channel 0 captures falling edge, if capture channel 0 fall lock interrupt (CFIE0) is enabled, this bit is set 1 by hardware.</p> <p>Write 1 to clear this bit.</p> <p>Reads 0: Capture channel 0 interrupt is not pending.</p> <p>1: Capture channel 0 interrupt is pending.</p> <p>Writes 0: no effect.</p> <p>1: Clear capture channel 0 interrupt status.</p> |
| 0              | R/W1C      | 0x0         | <p>CRIS0</p> <p>Capture channel 0 rising lock interrupt status</p> <p>When capture channel 0 captures rising edge, if capture channel 0 rise lock interrupt (CRIE0) is enabled, this bit is set 1 by hardware.</p> <p>Write 1 to clear this bit.</p> <p>Reads 0: Capture channel 0 interrupt is not pending.</p> <p>1: Capture channel 0 interrupt is pending.</p> <p>Writes 0: no effect.</p> <p>1: Clear capture channel 0 interrupt status.</p>   |

#### 8.14.6.5 0x0020 PWM01 Clock Configuration Register (Default Value: 0x0000\_0000)

| Register | PWMCTRL0 | PWMCTRL1 | S_PWMCTRL | MCU_PWMCTRL |
|----------|----------|----------|-----------|-------------|
| PCCR01   | Support  | Support  | Support   | Support     |

| Offset: 0x0020 |            |             | Register Name: PCCR01                                                                                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                             |
| 31:9           | /          | /           | /                                                                                                                                                                       |
| 8:7            | R/W        | 0x00        | PWM01_CLK_SRC<br>Select PWM01 clock source<br>00: OSC24M<br>01: APB1<br>Others: /                                                                                       |
| 6:4            | /          | /           | /                                                                                                                                                                       |
| 3:0            | R/W        | 0x0000      | PWM01_CLK_DIV_M<br>PWM01 clock divide M<br>0000: /1<br>0001: /2<br>0010: /4<br>0011: /8<br>0100: /16<br>0101: /32<br>0110: /64<br>0111: /128<br>1000: /256<br>others: / |

#### 8.14.6.6 0x0024 PWM23 Clock Configuration Register (Default Value: 0x0000\_0000)

| Register | PWMCTRL0 | PWMCTRL1 | S_PWMCTRL   | MCU_PWMCTRL |
|----------|----------|----------|-------------|-------------|
| PCCR23   | Support  | Support  | Not Support | Support     |

| Offset: 0x0024 |            |             | Register Name: PCCR23                                                                 |
|----------------|------------|-------------|---------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                           |
| 31:9           | /          | /           | /                                                                                     |
| 8:7            | R/W        | 0x00        | PWM23_CLK_SRC_SEL<br>Select PWM23 clock source<br>00: OSC24M<br>01: APB1<br>Others: / |
| 6:4            | /          | /           | /                                                                                     |
| 3:0            | R/W        | 0x0000      | PWM23_CLK_DIV_M<br>PWM23 clock divide M<br>0000: /1<br>0001: /2                       |

| Offset: 0x0024 |            |             | Register Name: PCCR23                                                                                |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                          |
|                |            |             | 0010: /4<br>0011: /8<br>0100: /16<br>0101: /32<br>0110: /64<br>0111: /128<br>1000: /256<br>others: / |

#### 8.14.6.7 0x0028 PWM45 Clock Configuration Register (Default Value: 0x0000\_0000)

| Register | PWMCTRL0 | PWMCTRL1    | S_PWMCTRL   | MCU_PWMCTRL |
|----------|----------|-------------|-------------|-------------|
| PCCR45   | Support  | Not Support | Not Support | Support     |

| Offset: 0x0028 |            |             | Register Name: PCCR45                                                                                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                             |
| 31:9           | /          | /           | /                                                                                                                                                                       |
| 8:7            | R/W        | 0x00        | PWM45_CLK_SRC_SEL<br>Select PWM45 clock source<br>00: OSC24M<br>01: APB1<br>Others: /                                                                                   |
| 6:4            | /          | /           | /                                                                                                                                                                       |
| 3:0            | R/W        | 0x0000      | PWM45_CLK_DIV_M<br>PWM45 clock divide M<br>0000: /1<br>0001: /2<br>0010: /4<br>0011: /8<br>0100: /16<br>0101: /32<br>0110: /64<br>0111: /128<br>1000: /256<br>others: / |

#### 8.14.6.8 0x002C PWM67 Clock Configuration Register (Default Value: 0x0000\_0000)

| Register | PWMCTRL0 | PWMCTRL1 | S_PWMCTRL | MCU_PWMCTRL |
|----------|----------|----------|-----------|-------------|
|          |          |          |           |             |

| Register | PWMCTRL0 | PWMCTRL1    | S_PWMCTRL   | MCU_PWMCTRL |
|----------|----------|-------------|-------------|-------------|
| PCCR67   | Support  | Not Support | Not Support | Support     |

| Offset: 0x002C |            |             | Register Name: PCCR67                                                                                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                             |
| 31:9           | /          | /           | /                                                                                                                                                                       |
| 8:7            | R/W        | 0x00        | PWM67_CLK_SRC_SEL<br>Select PWM67 clock source<br>00: OSC24M<br>01: APB1<br>Others: /                                                                                   |
| 6:4            | /          | /           | /                                                                                                                                                                       |
| 3:0            | R/W        | 0x0000      | PWM67_CLK_DIV_M<br>PWM67 clock divide M<br>0000: /1<br>0001: /2<br>0010: /4<br>0011: /8<br>0100: /16<br>0101: /32<br>0110: /64<br>0111: /128<br>1000: /256<br>others: / |

#### 8.14.6.9 0x0030 PWM89 Clock Configuration Register (Default Value: 0x0000\_0000)

| Register | PWMCTRL0 | PWMCTRL1    | S_PWMCTRL   | MCU_PWMCTRL |
|----------|----------|-------------|-------------|-------------|
| PCCR89   | Support  | Not Support | Not Support | Not Support |

| Offset: 0x0030 |            |             | Register Name: PCCR89                                                                 |
|----------------|------------|-------------|---------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                           |
| 31:9           | /          | /           | /                                                                                     |
| 8:7            | R/W        | 0x00        | PWM89_CLK_SRC_SEL<br>Select PWM89 clock source<br>00: OSC24M<br>01: APB1<br>Others: / |
| 6:4            | /          | /           | /                                                                                     |
| 3:0            | R/W        | 0x0000      | PWM89_CLK_DIV_M<br>PWM89 clock divide M                                               |

| Offset: 0x0030 |            |             | Register Name: PCCR89                                                                                                        |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                  |
|                |            |             | 0000: /1<br>0001: /2<br>0010: /4<br>0011: /8<br>0100: /16<br>0101: /32<br>0110: /64<br>0111: /128<br>1000: /256<br>others: / |

#### 8.14.6.10 0x0034 PWMab Clock Configuration Register (Default Value: 0x0000\_0000)

| Register | PWMCTRL0 | PWMCTRL1    | S_PWMCTRL   | MCU_PWMCTRL |
|----------|----------|-------------|-------------|-------------|
| PCCRab   | Support  | Not Support | Not Support | Not Support |

| Offset: 0x0034 |            |             | Register Name: PCCRab                                                                                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                             |
| 31:9           | /          | /           | /                                                                                                                                                                       |
| 8:7            | R/W        | 0x00        | PWMab_CLK_SRC_SEL<br>Select PWMab clock source<br>00: OSC24M<br>01: APB1<br>Others: /                                                                                   |
| 6:4            | /          | /           | /                                                                                                                                                                       |
| 3:0            | R/W        | 0x0000      | PWMab_CLK_DIV_M<br>PWMab clock divide M<br>0000: /1<br>0001: /2<br>0010: /4<br>0011: /8<br>0100: /16<br>0101: /32<br>0110: /64<br>0111: /128<br>1000: /256<br>others: / |

#### 8.14.6.11 0x0038 PWMcd Clock Configuration Register (Default Value: 0x0000\_0000)

| Register | PWMCTRL0 | PWMCTRL1    | S_PWMCTRL   | MCU_PWMCTRL |
|----------|----------|-------------|-------------|-------------|
| PCCRcd   | Support  | Not Support | Not Support | Not Support |

| Offset: 0x0038 |            |             | Register Name: PCCRcd                                                                                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                             |
| 31:9           | /          | /           | /                                                                                                                                                                       |
| 8:7            | R/W        | 0x00        | PWMcd_CLK_SRC_SEL<br>Select PWMcd clock source<br>00: OSC24M<br>01: APB1<br>Others: /                                                                                   |
| 6:4            | /          | /           | /                                                                                                                                                                       |
| 3:0            | R/W        | 0x0000      | PWMcd_CLK_DIV_M<br>PWMcd clock divide M<br>0000: /1<br>0001: /2<br>0010: /4<br>0011: /8<br>0100: /16<br>0101: /32<br>0110: /64<br>0111: /128<br>1000: /256<br>others: / |

#### 8.14.6.12 0x003C PWMeef Clock Configuration Register (Default Value: 0x0000\_0000)

| Register | PWMCTRL0 | PWMCTRL1    | S_PWMCTRL   | MCU_PWMCTRL |
|----------|----------|-------------|-------------|-------------|
| PCCRef   | Support  | Not Support | Not Support | Not Support |

| Offset: 0x003C |            |             | Register Name: PCCRef                                                                    |
|----------------|------------|-------------|------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                              |
| 31:9           | /          | /           | /                                                                                        |
| 8:7            | R/W        | 0x00        | PWMeef_CLK_SRC_SEL<br>Select PWMeef clock source<br>00: DCXO24M<br>01: APB1<br>Others: / |

| Offset: 0x003C |            |             | Register Name: PCCRef                                                                                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                             |
| 6:4            | /          | /           | /                                                                                                                                                                       |
| 3:0            | R/W        | 0x0000      | PWMef_CLK_DIV_M<br>PWMef clock divide M<br>0000: /1<br>0001: /2<br>0010: /4<br>0011: /8<br>0100: /16<br>0101: /32<br>0110: /64<br>0111: /128<br>1000: /256<br>others: / |

#### 8.14.6.13 0x0040 PWM Clock Gating Register (Default Value: 0x0000\_0000)

| Offset: 0x0040 |            |             | Register Name: PCGR                                                                                                                                     |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                             |
| 31             | R/W        | 0x0         | PWM15_CLK_BYPASS<br>Bypass clock source (after pre-scale ) to PWM15 output<br>0: not bypass<br>1: bypass<br><b>Note: This bit is only for PWMCTRL0.</b> |
| 30             | R/W        | 0x0         | PWM14_CLK_BYPASS<br>Bypass clock source (after pre-scale ) to PWM14 output<br>0: not bypass<br>1: bypass<br><b>Note: This bit is only for PWMCTRL0.</b> |
| 29             | R/W        | 0x0         | PWM13_CLK_BYPASS<br>Bypass clock source(after pre-scale ) to PWM13 output<br>0: not bypass<br>1: bypass<br><b>Note: This bit is only for PWMCTRL0.</b>  |
| 28             | R/W        | 0x0         | PWM12_CLK_BYPASS<br>Bypass clock source (after pre-scale ) to PWM12 output<br>0: not bypass<br>1: bypass                                                |

| Offset: 0x0040 |            |             | Register Name: PCGR                                                                                                                                                  |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                          |
|                |            |             | <b>Note:</b> This bit is only for PWMCTRL0.                                                                                                                          |
| 27             | R/W        | 0x0         | PWM11_CLK_BYPASS<br>Bypass clock source(after pre-scale ) to PWM11 output<br>0: not bypass<br>1: bypass<br><b>Note:</b> This bit is only for PWMCTRL0.               |
| 26             | R/W        | 0x0         | PWM10_CLK_BYPASS<br>Bypass clock source(after pre-scale ) to PWM10 output<br>0: not bypass<br>1: bypass<br><b>Note:</b> This bit is only for PWMCTRL0.               |
| 25             | R/W        | 0x0         | PWM9_CLK_BYPASS<br>Bypass clock source(after pre-scale ) to PWM9 output<br>0: not bypass<br>1: bypass<br><b>Note:</b> This bit is only for PWMCTRL0.                 |
| 24             | R/W        | 0x0         | PWM8_CLK_BYPASS<br>Bypass clock source(after pre-scale ) to PWM8 output<br>0: not bypass<br>1: bypass<br><b>Note:</b> This bit is only for PWMCTRL0.                 |
| 23             | R/W        | 0x0         | PWM7_CLK_BYPASS<br>Bypass clock source(after pre-scale ) to PWM7 output<br>0: not bypass<br>1: bypass<br><b>Note:</b> This bit is only for PWMCTRL0 and MCU_PWMCTRL. |
| 22             | R/W        | 0x0         | PWM6_CLK_BYPASS<br>Bypass clock source(after pre-scale ) to PWM6 output<br>0: not bypass<br>1: bypass<br><b>Note:</b> This bit is only for PWMCTRL0 and MCU_PWMCTRL. |
| 21             | R/W        | 0x0         | PWM5_CLK_BYPASS<br>Bypass clock source(after pre-scale ) to PWM5                                                                                                     |

| Offset: 0x0040 |            |             | Register Name: PCGR                                                                                                                                                                    |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                            |
|                |            |             | output<br>0: not bypass<br>1: bypass<br><b>Note: This bit is only for PWMCTRL0 and MCU_PWMCTRL.</b>                                                                                    |
| 20             | R/W        | 0x0         | <b>PWM4_CLK_BYPASS</b><br>Bypass clock source(after pre-scale ) to PWM4 output<br>0: not bypass<br>1: bypass<br><b>Note: This bit is only for PWMCTRL0 and MCU_PWMCTRL.</b>            |
| 19             | R/W        | 0x0         | <b>PWM3_CLK_BYPASS</b><br>Bypass clock source(after pre-scale ) to PWM3 output<br>0: not bypass<br>1: bypass<br><b>Note: This bit is only for PWMCTRL0, PWMCTRL1, and MCU_PWMCTRL.</b> |
| 18             | R/W        | 0x0         | <b>PWM2_CLK_BYPASS</b><br>Bypass clock source(after pre-scale ) to PWM2 output<br>0: not bypass<br>1: bypass<br><b>Note: This bit is only for PWMCTRL0, PWMCTRL1, and MCU_PWMCTRL.</b> |
| 17             | R/W        | 0x0         | <b>PWM1_CLK_BYPASS</b><br>Bypass clock source(after pre-scale ) to PWM1 output<br>0: not bypass<br>1: bypass                                                                           |
| 16             | R/W        | 0x0         | <b>PWM0_CLK_BYPASS</b><br>Bypass clock source (after pre-scale ) to PWM0 output<br>0: not bypass<br>1: bypass                                                                          |
| 15             | R/W        | 0x0         | <b>PWM15_CLK_GATING</b><br>Gating clock for PWM15<br>0: Mask<br>1: Pass<br><b>Note: This bit is only for PWMCTRL0.</b>                                                                 |

| Offset: 0x0040 |            |             | Register Name: PCGR                                                                                                           |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                   |
| 14             | R/W        | 0x0         | PWM14_CLK_GATING<br>Gating clock for PWM14<br>0: Mask<br>1: Pass<br><b>Note: This bit is only for PWMCTRL0.</b>               |
| 13             | R/W        | 0x0         | PWM13_CLK_GATING<br>Gating clock for PWM13<br>0: Mask<br>1: Pass<br><b>Note: This bit is only for PWMCTRL0.</b>               |
| 12             | R/W        | 0x0         | PWM12_CLK_GATING<br>Gating clock for PWM12<br>0: Mask<br>1: Pass<br><b>Note: This bit is only for PWMCTRL0.</b>               |
| 11             | R/W        | 0x0         | PWM11_CLK_GATING<br>Gating clock for PWM11<br>0: Mask<br>1: Pass<br><b>Note: This bit is only for PWMCTRL0.</b>               |
| 10             | R/W        | 0x0         | PWM10_CLK_GATING<br>Gating clock for PWM10<br>0: Mask<br>1: Pass<br><b>Note: This bit is only for PWMCTRL0.</b>               |
| 9              | R/W        | 0x0         | PWM9_CLK_GATING<br>Gating clock for PWM9<br>0: Mask<br>1: Pass<br><b>Note: This bit is only for PWMCTRL0.</b>                 |
| 8              | R/W        | 0x0         | PWM8_CLK_GATING<br>Gating clock for PWM8<br>0: Mask<br>1: Pass<br><b>Note: This bit is only for PWMCTRL0.</b>                 |
| 7              | R/W        | 0x0         | PWM7_CLK_GATING<br>Gating clock for PWM7<br>0: Mask<br>1: Pass<br><b>Note: This bit is only for PWMCTRL0 and MCU_PWMCTRL.</b> |

| Offset: 0x0040 |            |             | Register Name: PCGR                                                                                                                      |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                              |
| 6              | R/W        | 0x0         | PWM6_CLK_GATING<br>Gating clock for PWM6<br>0: Mask<br>1: Pass<br><b>Note: This bit is only for PWMCTRL0 and MCU_PWMCTRL.</b>            |
| 5              | R/W        | 0x0         | PWM5_CLK_GATING<br>Gating clock for PWM5<br>0: Mask<br>1: Pass<br><b>Note: This bit is only for PWMCTRL0 and MCU_PWMCTRL.</b>            |
| 4              | R/W        | 0x0         | PWM4_CLK_GATING<br>Gating clock for PWM4<br>0: Mask<br>1: Pass<br><b>Note: This bit is only for PWMCTRL0 and MCU_PWMCTRL.</b>            |
| 3              | R/W        | 0x0         | PWM3_CLK_GATING<br>Gating clock for PWM3<br>0: Mask<br>1: Pass<br><b>Note: This bit is only for PWMCTRL0, PWMCTRL1, and MCU_PWMCTRL.</b> |
| 2              | R/W        | 0x0         | PWM2_CLK_GATING<br>Gating clock for PWM2<br>0: Mask<br>1: Pass<br><b>Note: This bit is only for PWMCTRL0, PWMCTRL1, and MCU_PWMCTRL.</b> |
| 1              | R/W        | 0x0         | PWM1_CLK_GATING<br>Gating clock for PWM1<br>0: Mask<br>1: Pass                                                                           |
| 0              | R/W        | 0x0         | PWM0_CLK_GATING<br>Gating clock for PWM0<br>0: Mask<br>1: Pass                                                                           |

#### 8.14.6.14 0x0060 PWM01 Dead Zone Control Register (Default Value: 0x0000\_0000)

| Register | PWMCTRL0 | PWMCTRL1 | S_PWMCTRL | MCU_PWMCTRL |
|----------|----------|----------|-----------|-------------|
| PDZCR01  | Support  | Support  | Support   | Support     |

| Offset: 0x0060 |            |             | Register Name: PDZCR01                                                               |
|----------------|------------|-------------|--------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                          |
| 31:16          | /          | /           | /                                                                                    |
| 15:8           | R/W        | 0x0         | PDZINTV01<br>PWM01 Dead Zone interval value                                          |
| 7:1            | /          | /           | /                                                                                    |
| 0              | R/W        | 0x0         | PWM01_DZ_EN<br>PWM01 Dead Zone enable<br>0: Dead Zone disable<br>1: Dead Zone enable |

#### 8.14.6.15 0x0064 PWM23 Dead Zone Control Register (Default Value: 0x0000\_0000)

| Register | PWMCTRL0 | PWMCTRL1 | S_PWMCTRL   | MCU_PWMCTRL |
|----------|----------|----------|-------------|-------------|
| PDZCR23  | Support  | Support  | Not Support | Support     |

| Offset: 0x0064 |            |             | Register Name: PDZCR23                                                               |
|----------------|------------|-------------|--------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                          |
| 31:16          | /          | /           | /                                                                                    |
| 15:8           | R/W        | 0x0         | PWM23_DZ_INTV<br>PWM23 Dead Zone interval value                                      |
| 7:1            | /          | /           | /                                                                                    |
| 0              | R/W        | 0x0         | PWM23_DZ_EN<br>PWM23 Dead Zone enable<br>0: Dead Zone disable<br>1: Dead Zone enable |

#### 8.14.6.16 0x0068 PWM45 Dead Zone Control Register (Default Value: 0x0000\_0000)

| Register | PWMCTRL0 | PWMCTRL1    | S_PWMCTRL   | MCU_PWMCTRL |
|----------|----------|-------------|-------------|-------------|
| PDZCR45  | Support  | Not Support | Not Support | Support     |

| Offset: 0x0068 |            |             | Register Name: PDZCR45 |
|----------------|------------|-------------|------------------------|
| Bit            | Read/Write | Default/Hex | Description            |

| Offset: 0x0068 |            |             | Register Name: PDZCR45                                                               |
|----------------|------------|-------------|--------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                          |
| 31:16          | /          | /           | /                                                                                    |
| 15:8           | R/W        | 0x0         | PWM45_DZ_INTV<br>PWM45 Dead Zone interval value                                      |
| 7:1            | /          | /           | /                                                                                    |
| 0              | R/W        | 0x0         | PWM45_DZ_EN<br>PWM45 Dead Zone enable<br>0: Dead Zone disable<br>1: Dead Zone enable |

#### 8.14.6.17 0x006C PWM67 Dead Zone Control Register (Default Value: 0x0000\_0000)

| Register | PWMCTRL0 | PWMCTRL1    | S_PWMCTRL   | MCU_PWMCTRL |
|----------|----------|-------------|-------------|-------------|
| PDZCR67  | Support  | Not Support | Not Support | Support     |

| Offset: 0x006C |            |             | Register Name: PDZCR67                                                               |
|----------------|------------|-------------|--------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                          |
| 31:16          | /          | /           | /                                                                                    |
| 15:8           | R/W        | 0x0         | PWM67_DZ_INTV<br>PWM67 Dead Zone interval value                                      |
| 7:1            | /          | /           | /                                                                                    |
| 0              | R/W        | 0x0         | PWM67_DZ_EN<br>PWM67 Dead Zone enable<br>0: Dead Zone disable<br>1: Dead Zone enable |

#### 8.14.6.18 0x0070 PWM89 Dead Zone Control Register (Default Value: 0x0000\_0000)

| Register | PWMCTRL0 | PWMCTRL1    | S_PWMCTRL   | MCU_PWMCTRL |
|----------|----------|-------------|-------------|-------------|
| PDZCR89  | Support  | Not Support | Not Support | Not Support |

| Offset: 0x0070 |            |             | Register Name: PDZCR89                          |
|----------------|------------|-------------|-------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                     |
| 31:16          | /          | /           | /                                               |
| 15:8           | R/W        | 0x0         | PWM89_DZ_INTV<br>PWM89 Dead Zone interval value |
| 7:1            | /          | /           | /                                               |
| 0              | R/W        | 0x0         | PWM89_DZ_EN<br>PWM89 Dead Zone enable           |

| Offset: 0x0070 |            |             | Register Name: PDZCR89                      |
|----------------|------------|-------------|---------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                 |
|                |            |             | 0: Dead Zone disable<br>1: Dead Zone enable |
|                |            |             |                                             |

#### 8.14.6.19 0x0074 PWMab Dead Zone Control Register (Default Value: 0x0000\_0000)

| Register | PWMCTRL0 | PWMCTRL1    | S_PWMCTRL   | MCU_PWMCTRL |
|----------|----------|-------------|-------------|-------------|
| PDZCRab  | Support  | Not Support | Not Support | Not Support |

| Offset: 0x0074 |            |             | Register Name: PDZCRab                                                               |
|----------------|------------|-------------|--------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                          |
| 31:16          | /          | /           | /                                                                                    |
| 15:8           | R/W        | 0x0         | PWMab_DZ_INTV<br>PWMab Dead Zone interval value                                      |
| 7:1            | /          | /           | /                                                                                    |
| 0              | R/W        | 0x0         | PWMab_DZ_EN<br>PWMab Dead Zone enable<br>0: Dead Zone disable<br>1: Dead Zone enable |

#### 8.14.6.20 0x0078 PWMcd Dead Zone Control Register (Default Value: 0x0000\_0000)

| Register | PWMCTRL0 | PWMCTRL1    | S_PWMCTRL   | MCU_PWMCTRL |
|----------|----------|-------------|-------------|-------------|
| PDZCRcd  | Support  | Not Support | Not Support | Not Support |

| Offset: 0x0078 |            |             | Register Name: PDZCRcd                                                               |
|----------------|------------|-------------|--------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                          |
| 31:16          | /          | /           | /                                                                                    |
| 15:8           | R/W        | 0x0         | PWMcd_DZ_INTV<br>PWMcd Dead Zone interval value                                      |
| 7:1            | /          | /           | /                                                                                    |
| 0              | R/W        | 0x0         | PWMcd_DZ_EN<br>PWMcd Dead Zone enable<br>0: Dead Zone disable<br>1: Dead Zone enable |

#### 8.14.6.21 0x007C PWMef Dead Zone Control Register (Default Value: 0x0000\_0000)

| Register | PWMCTRL0 | PWMCTRL1    | S_PWMCTRL   | MCU_PWMCTRL |
|----------|----------|-------------|-------------|-------------|
| PDZCRef  | Support  | Not Support | Not Support | Not Support |

| Offset: 0x007C |            |             | Register Name: PDZCRef                                                               |
|----------------|------------|-------------|--------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                          |
| 31:16          | /          | /           | /                                                                                    |
| 15:8           | R/W        | 0x0         | PWMef_DZ_INTV<br>PWMef Dead Zone interval value                                      |
| 7:1            | /          | /           | /                                                                                    |
| 0              | R/W        | 0x0         | PWMef_DZ_EN<br>PWMef Dead Zone enable<br>0: Dead Zone disable<br>1: Dead Zone enable |

#### 8.14.6.22 0x0080 PWM Enable Register (Default Value: 0x0000\_0000)



For PWMCTRL1, bit [15:4] are reserved.

For S\_PWMCTRL, bit [15:2] are reserved.

For MCU\_PWMCTRL, bit [15:8] are reserved.

| Offset: 0x0080 |            |             | Register Name: PER                                                   |
|----------------|------------|-------------|----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                          |
| 31:16          | /          | /           | /                                                                    |
| 15             | R/W        | 0x0         | PWM15_EN<br>PWM Channel 15 Enable<br>0: PWM disable<br>1: PWM enable |
| 14             | R/W        | 0x0         | PWM14_EN<br>PWM Channel14 Enable<br>0: PWM disable<br>1: PWM enable  |
| 13             | R/W        | 0x0         | PWM13_EN<br>PWM Channel 13 Enable<br>0: PWM disable<br>1: PWM enable |
| 12             | R/W        | 0x0         | PWM12_EN                                                             |

| Offset: 0x0080 |            |             | Register Name: PER                                                   |
|----------------|------------|-------------|----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                          |
|                |            |             | PWM Channel 12 Enable<br>0: PWM disable<br>1: PWM enable             |
| 11             | R/W        | 0x0         | PWM11_EN<br>PWM Channel 11 Enable<br>0: PWM disable<br>1: PWM enable |
| 10             | R/W        | 0x0         | PWM10_EN<br>PWM Channel 10 Enable<br>0: PWM disable<br>1: PWM enable |
| 9              | R/W        | 0x0         | PWM9_EN<br>PWM Channel 9 Enable<br>0: PWM disable<br>1: PWM enable   |
| 8              | R/W        | 0x0         | PWM8_EN<br>PWM Channel 8 Enable<br>0: PWM disable<br>1: PWM enable   |
| 7              | R/W        | 0x0         | PWM7_EN<br>PWM Channel 7 Enable<br>0: PWM disable<br>1: PWM enable   |
| 6              | R/W        | 0x0         | PWM6_EN<br>PWM Channel 6 Enable<br>0: PWM disable<br>1: PWM enable   |
| 5              | R/W        | 0x0         | PWM5_EN<br>PWM Channel 5 Enable<br>0: PWM disable<br>1: PWM enable   |
| 4              | R/W        | 0x0         | PWM4_EN<br>PWM Channel 4 Enable<br>0: PWM disable<br>1: PWM enable   |
| 3              | R/W        | 0x0         | PWM3_EN<br>PWM Channel 3 Enable<br>0: PWM disable<br>1: PWM enable   |
| 2              | R/W        | 0x0         | PWM2_EN<br>PWM Channel 2 Enable                                      |

| Offset: 0x0080 |            |             | Register Name: PER                                                 |
|----------------|------------|-------------|--------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                        |
|                |            |             | 0: PWM disable<br>1: PWM enable                                    |
| 1              | R/W        | 0x0         | PWM1_EN<br>PWM Channel 1 Enable<br>0: PWM disable<br>1: PWM enable |
| 0              | R/W        | 0x0         | PWM0_EN<br>PWM Channel 0 Enable<br>0: PWM disable<br>1: PWM enable |

#### 8.14.6.23 0x0090 PWM Group0 Register (Default Value: 0x0000\_0000)

| Offset: 0x0090 |            |             | Register Name: PGR0                                                                             |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                     |
| 31:18          | /          | /           | /                                                                                               |
| 17             | R/WAC      | 0x0         | PWMG0_START<br>PWM channels selected in PWMG0_CS start to output PWM waveform at the same time. |
| 16             | R/W        | 0x0         | PWMG0_EN<br>PWM Group0 Enable                                                                   |
| 15:0           | R/W        | 0x0         | PWMG0_CS<br>If bit[i] is set, PWM i is selected as one channel of PWM Group0                    |

#### 8.14.6.24 0x0094 PWM Group1 Register (Default Value: 0x0000\_0000)

| Offset: 0x0094 |            |             | Register Name: PGR1                                                                             |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                     |
| 31:18          | /          | /           | /                                                                                               |
| 17             | R/WAC      | 0x0         | PWMG1_START<br>PWM channels selected in PWMG1_CS start to output PWM waveform at the same time. |
| 16             | R/W        | 0x0         | PWMG1_EN<br>PWM Group1 Enable                                                                   |
| 15:0           | R/W        | 0x0         | PWMG1_CS<br>If bit[i] is set, PWM i is selected as one channel of PWM Group1.                   |

#### 8.14.6.25 0x0098 PWM Group2 Register (Default Value: 0x0000\_0000)

| Offset: 0x0098 |            |             | Register Name: PGR2                                                                             |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                     |
| 31:18          | /          | /           | /                                                                                               |
| 17             | R/WAC      | 0x0         | PWMG2_START<br>PWM channels selected in PWMG2_CS start to output PWM waveform at the same time. |
| 16             | R/W        | 0x0         | PWMG2_EN<br>PWM Group2 Enable                                                                   |
| 15:0           | R/W        | 0x0         | PWMG2_CS<br>If bit[i] is set, PWM i is selected as one channel of PWM Group2.                   |

#### 8.14.6.26 0x009C PWM Group3 Register (Default Value: 0x0000\_0000)

| Offset: 0x009C |            |             | Register Name: PGR3                                                                             |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                     |
| 31:18          | /          | /           | /                                                                                               |
| 17             | R/WAC      | 0x0         | PWMG3_START<br>PWM channels selected in PWMG3_CS start to output PWM waveform at the same time. |
| 16             | R/W        | 0x0         | PWMG3_EN<br>PWM Group2 Enable                                                                   |
| 15:0           | R/W        | 0x0         | PWMG3_CS<br>If bit[i] is set, PWM i is selected as one channel of PWM Group3.                   |

#### 8.14.6.27 0x00C0 Capture Enable Register (Default Value: 0x0000\_0000)



For PWMCTRL1, bit [15:4] are reserved.

For S\_PWMCTRL, bit [15:2] are reserved.

For MCU\_PWWMCTRL, bit [15:8] are reserved.

| Offset: 0x00C0 |            |             | Register Name: CER |
|----------------|------------|-------------|--------------------|
| Bit            | Read/Write | Default/Hex | Description        |
| 31:16          | /          | /           | /                  |
| 15             | R/W        | 0x0         | CAP15_EN           |

| Offset: 0x00C0 |            |             | Register Name: CER                                                                                                                                                                                             |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                    |
|                |            |             | When enable capture function, the 16-bit up-counter starts working and capture channel 15 is permitted to capture external falling edge or rising edge.<br>0: Capture disable<br>1: Capture enable             |
| 14             | R/W        | 0x0         | CAP14_EN<br>When enable capture function, the 16-bit up-counter starts working and capture channel 14 is permitted to capture external falling edge or rising edge.<br>0: Capture disable<br>1: Capture enable |
| 13             | R/W        | 0x0         | CAP13_EN<br>When enable capture function, the 16-bit up-counter starts working and capture channel 13 is permitted to capture external falling edge or rising edge.<br>0: Capture disable<br>1: Capture enable |
| 12             | R/W        | 0x0         | CAP12_EN<br>When enable capture function, the 16-bit up-counter starts working and capture channel 12 is permitted to capture external falling edge or rising edge.<br>0: Capture disable<br>1: Capture enable |
| 11             | R/W        | 0x0         | CAP11_EN<br>When enable capture function, the 16-bit up-counter starts working and capture channel 11 is permitted to capture external falling edge or rising edge.<br>0: Capture disable<br>1: Capture enable |
| 10             | R/W        | 0x0         | CAP10_EN<br>When enable capture function, the 16-bit up-counter starts working and capture channel 10 is permitted to capture external falling edge or rising edge.<br>0: Capture disable<br>1: Capture enable |

| Offset: 0x00C0 |            |             | Register Name: CER                                                                                                                                                                                           |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                  |
| 9              | R/W        | 0x0         | CAP9_EN<br>When enable capture function, the 16-bit up-counter starts working and capture channel 9 is permitted to capture external falling edge or rising edge.<br>0: Capture disable<br>1: Capture enable |
| 8              | R/W        | 0x0         | CAP8_EN<br>When enable capture function, the 16-bit up-counter starts working and capture channel 8 is permitted to capture external falling edge or rising edge.<br>0: Capture disable<br>1: Capture enable |
| 7              | R/W        | 0x0         | CAP7_EN<br>When enable capture function, the 16-bit up-counter starts working and capture channel 7 is permitted to capture external falling edge or rising edge.<br>0: Capture disable<br>1: Capture enable |
| 6              | R/W        | 0x0         | CAP6_EN<br>When enable capture function, the 16-bit up-counter starts working and capture channel 6 is permitted to capture external falling edge or rising edge.<br>0: Capture disable<br>1: Capture enable |
| 5              | R/W        | 0x0         | CAP5_EN<br>When enable capture function, the 16-bit up-counter starts working and capture channel5 is permitted to capture external falling edge or rising edge.<br>0: Capture disable<br>1: Capture enable  |
| 4              | R/W        | 0x0         | CAP4_EN<br>When enable capture function, the 16-bit up-counter starts working and capture channel4 is permitted to capture external falling edge or rising edge.<br>0: Capture disable                       |

| Offset: 0x00C0 |            |             | Register Name: CER                                                                                                                                                                                          |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                 |
|                |            |             | 1: Capture enable                                                                                                                                                                                           |
| 3              | R/W        | 0x0         | CAP3_EN<br>When enable capture function, the 16-bit up-counter starts working and capture channel3 is permitted to capture external falling edge or rising edge.<br>0: Capture disable<br>1: Capture enable |
| 2              | R/W        | 0x0         | CAP2_EN<br>When enable capture function, the 16-bit up-counter starts working and capture channel2 is permitted to capture external falling edge or rising edge.<br>0: Capture disable<br>1: Capture enable |
| 1              | R/W        | 0x0         | CAP1_EN<br>When enable capture function, the 16-bit up-counter starts working and capture channel1 is permitted to capture external falling edge or rising edge.<br>0: Capture disable<br>1: Capture enable |
| 0              | R/W        | 0x0         | CAP0_EN<br>When enable capture function, the 16-bit up-counter starts working and capture channel is permitted to capture external falling edge or rising edge.<br>0: Capture disable<br>1: Capture enable  |

#### 8.14.6.28 0x0100+N\*0x0020 PWM Control Register (Default Value: 0x0000\_0000)

| Register | PWMCTRL0   | PWMCTRL1  | S_PWMCTRL | MCU_PWMCTRL |
|----------|------------|-----------|-----------|-------------|
| PCR      | N= 0 to 15 | N= 0 to 3 | N= 0, 1   | N= 0 to 7   |

| Offset: 0x0100+N*0x0020 |            |             | Register Name: PCR                                                                      |
|-------------------------|------------|-------------|-----------------------------------------------------------------------------------------|
| Bit                     | Read/Write | Default/Hex | Description                                                                             |
| 31:16                   | R/W        | 0x0         | PWM_PUL_NUM<br>In pulse mode, PWM output pulse for PWM_CYCLE_NUM+1 times and then stop. |

| Offset: 0x0100+N*0x0020 |            |             | Register Name: PCR                                                                                                                                                                                                                                                                 |
|-------------------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                     | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                        |
| 15:12                   | /          | /           | /                                                                                                                                                                                                                                                                                  |
| 11                      | R          | 0x0         | PWM_PERIOD_RDY<br>PWM period register ready<br>0: PWM period register is ready to write<br>1: PWM period register is busy.                                                                                                                                                         |
| 10                      | R/WAC      | 0x0         | PWM_PUL_START<br>PWM pulse output start<br>0: no effect<br>1: output pulse for PWM_CYCLE_NUM+1<br>After finishing configuration for outputting pulse, set this bit once and then PWM would output waveform. After the waveform is finished, the bit will be cleared automatically. |
| 9                       | R/W        | 0x0         | PWM_MODE<br>PWM output mode select<br>0: cycle mode<br>1: pulse mode                                                                                                                                                                                                               |
| 8                       | R/W        | 0x0         | PWM_ACT_STA<br>PWM active state<br>0: Low Level<br>1: High Level                                                                                                                                                                                                                   |
| 7:0                     | R/W        | 0x0         | PWM_PRESCAL_K<br>PWM pre-scale K, actual pre-scale is (K+1)<br>K = 0, actual pre-scale: 1<br>K = 1, actual pre-scale: 2<br>K = 2, actual pre-scale: 3<br>K = 3, actual pre-scale: 4<br>.....<br>K = 255, actual pre-scale: 256                                                     |

#### 8.14.6.29 0x0104+N\*0x0020 PWM Period Register (Default Value: 0x0000\_0000)

| Register | PWMCTRL0   | PWMCTRL1  | S_PWMCTRL | MCU_PWMCTRL |
|----------|------------|-----------|-----------|-------------|
| PPR      | N= 0 to 15 | N= 0 to 3 | N= 0, 1   | N= 0 to 7   |

| Offset: 0x0104+N*0x0020 |            |             | Register Name: PPR                                                              |
|-------------------------|------------|-------------|---------------------------------------------------------------------------------|
| Bit                     | Read/Write | Default/Hex | Description                                                                     |
| 31:16                   | R/W        | 0x0         | PWM_ENTIRE_CYCLE<br>Number of the entire cycles in the PWM clock<br>0 = 1 cycle |

| Offset: 0x0104+N*0x0020 |            |             | Register Name: PPR                                                                                                                                                             |
|-------------------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                     | Read/Write | Default/Hex | Description                                                                                                                                                                    |
|                         |            |             | <p>1 = 2 cycles<br/>         .....<br/>         N = N+1 cycles<br/>         If the register need to be modified dynamically, the PCLK should be faster than the PWM CLK .</p>  |
| 15:0                    | R/W        | 0x0         | <p>PWM_ACT_CYCLE<br/>         Number of the active cycles in the PWM clock<br/>         0 = 0 cycle<br/>         1 = 1 cycles<br/>         .....<br/>         N = N cycles</p> |

#### 8.14.6.30 0x0108+N\*0x0020 PWM Counter Register (Default Value: 0x0000\_0000)

| Register | PWMCTRL0   | PWMCTRL1  | S_PWMCTRL | MCU_PWMCTRL |
|----------|------------|-----------|-----------|-------------|
| PCNTR    | N= 0 to 15 | N= 0 to 3 | N= 0, 1   | N= 0 to 7   |

| Offset: 0x0108+N*0x0020 |            |             | Register Name: PCNTR                                                                                                                                   |
|-------------------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                     | Read/Write | Default/Hex | Description                                                                                                                                            |
| 31:16                   | R/W        | 0x0         | <p>PWM_COUNTER_START<br/>         PWM counter value is set for phase control.</p>                                                                      |
| 15:0                    | R          | 0x0         | <p>PWM_COUNTER_STATUS<br/>         On PWM output or capture input, reading this register could get the current value of the PWM 16 bit up-counter.</p> |

#### 8.14.6.31 0x010C+N\*0x0020 PWM Pulse Counter Register (Default Value: 0x0000\_0000)

| Register | PWMCTRL0   | PWMCTRL1  | S_PWMCTRL | MCU_PWMCTRL |
|----------|------------|-----------|-----------|-------------|
| PPCNTR   | N= 0 to 15 | N= 0 to 3 | N= 0, 1   | N= 0 to 7   |

| Offset: 0x010C+N*0x0020 |            |             | Register Name: PPCNTR                                                                                                                  |
|-------------------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------|
| Bit                     | Read/Write | Default/Hex | Description                                                                                                                            |
| 31:16                   | /          | /           | /                                                                                                                                      |
| 15:0                    | R          | 0x0         | <p>PWM_PUL_COUNTER_STATUS<br/>         On PWM output , reading this register could get the current value of the PWM pulse counter.</p> |

#### 8.14.6.32 0x0110+N\*0x0020 Capture Control Register (Default Value: 0x0000\_0000)

| Register | PWMCTRL0   | PWMCTRL1  | S_PWMCTRL | MCU_PWMCTRL |
|----------|------------|-----------|-----------|-------------|
| CCR      | N= 0 to 15 | N= 0 to 3 | N= 0, 1   | N= 0 to 7   |

| Offset: 0x0110+N*0x0020 |            |             | Register Name: CCR                                                                                                                                                                                 |
|-------------------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit                     | Read/Write | Default/Hex | Description                                                                                                                                                                                        |
| 31:5                    | /          | /           | /                                                                                                                                                                                                  |
| 4                       | R/W1C      | 0x0         | CRLF<br>When capture channel captures rising edge, the 16-bit up-counter's current value is latched to CRLR and then this bit is set 1 by hardware.<br>Write 1 to clear this bit.                  |
| 3                       | R/W1C      | 0x0         | CFLF<br>When capture channel captures falling edge, the 16-bit up-counter's current value is latched to <a href="#">CFLR</a> and then this bit is set 1 by hardware.<br>Write 1 to clear this bit. |
| 2                       | R/W        | 0x0         | CRTE<br>Rising edge capture trigger enable                                                                                                                                                         |
| 1                       | R/W        | 0x0         | CFTE<br>Falling edge capture trigger enable                                                                                                                                                        |
| 0                       | R/W        | 0x0         | CAPINV<br>Inversing the signal inputted from capture channel before capture channel's 16bit counter.<br>0: not inverse<br>1: inverse                                                               |

#### 8.14.6.33 0x0114+N\*0x0020 Capture Rise Lock Register (Default Value: 0x0000\_0000)

| Register | PWMCTRL0   | PWMCTRL1  | S_PWMCTRL | MCU_PWMCTRL |
|----------|------------|-----------|-----------|-------------|
| CRLR     | N= 0 to 15 | N= 0 to 3 | N= 0, 1   | N= 0 to 7   |

| Offset: 0x0114+N*0x0020 |            |             | Register Name: CRLR                                                                                                   |
|-------------------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------|
| Bit                     | Read/Write | Default/Hex | Description                                                                                                           |
| 31:16                   | /          | /           | /                                                                                                                     |
| 15:0                    | R          | 0x0         | CRLR<br>When capture channel captures rising edge, the 16-bit up-counter's current value is latched to this register. |

## 8.14.6.34 0x0118+N\*0x0020 Capture Fall Lock Register (Default Value: 0x0000\_0000)

| Register | PWMCTRL0   | PWMCTRL1  | S_PWMCTRL | MCU_PWMCTRL |
|----------|------------|-----------|-----------|-------------|
| CFLR     | N= 0 to 15 | N= 0 to 3 | N= 0, 1   | N= 0 to 7   |

| Offset: 0x0118+N*0x0020 |            |             | Register Name: CFLR                                                                                                    |
|-------------------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------|
| Bit                     | Read/Write | Default/Hex | Description                                                                                                            |
| 31:16                   | /          | /           | /                                                                                                                      |
| 15:0                    | R          | 0x0         | CFLR<br>When capture channel captures falling edge, the 16-bit up-counter's current value is latched to this register. |

## 8.15 SPI

### 8.15.1 Overview

The Serial Peripheral Interface (SPI) is a full-duplex, synchronous, four-wire serial communication interface between a CPU and SPI-compliant external devices. The SPI controller contains a 64 x 8 bits receiver buffer (RXFIFO) and a 64 x 8 bits transmit buffer (TXFIFO). It can work in master mode and slave mode.

The SPI has the following features:

- Three SPI interfaces:
  - SPI0 and SPI2 in CPUX Domain
  - S\_SPI0 in CPUS Domain
- Multiple SPI modes:
  - Master mode and slave mode for standard SPI
  - Master mode for Dual-Output/Dual-Input SPI and Dual I/O SPI
  - Master mode for Quad-Output/Quad-Input SPI
  - Master mode for 3-wire SPI, with programmable serial data frame length of 1 bit to 32 bits
- Maximum clock frequency: 100MHz
- TX/RX DMA slave interface
- 8-bit wide and 64-entry FIFO for both transmitting and receiving data
- 8-bit wide and 4-entry buffer for transmitting
- 8-bit wide and 128-entry buffer for receiving data
- Supports mode0, mode1, mode2, and mode3
- Polarity and phase of the Chip Select (SPI\_SS) and SPI Clock (SPI\_SCLK) are configurable



#### NOTE

This chapter only describes SPI0, SPI2, and S\_SPI0. For detailed information of SPI1 (supports SPI mode and DBI mode), please refer to section 8.16 SPI\_DBI.

### 8.15.2 Block Diagram

The following figure shows a block diagram of the SPI.

**Figure 8-63 SPI Block Diagram**



SPI contains the following sub-blocks:

**Table 8-40 SPI Sub-blocks**

| Sub-block      | Description                                                                                                                                                                       |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| spi_rf         | Responsible for implementing the internal register, interrupt, and DMA Request.                                                                                                   |
| spi_tbuf       | The data length transmitted from AHB to TXFIFO is converted into 8 bits, then the data is written into the RXFIFO.                                                                |
| spi_rbuf       | The block is used to convert the RXFIFO data into the reading data length of AHB.                                                                                                 |
| txfifo, rxfifo | The data transmitted from the SPI to the external serial device is written into the TXFIFO; the data received from the external serial device into SPI is pushed into the RXFIFO. |
| spi_cmu        | Responsible for implementing SPI bus clock, chip select, internal sample, and the generation of transfer clock.                                                                   |
| spi_tx         | Responsible for implementing SPI data transfer, the interface of the internal TXFIFO, and status register.                                                                        |
| spi_rx         | Responsible for implementing SPI data receive, the interface of the internal RXFIFO, and status register.                                                                         |

### 8.15.3 Functional Description

#### 8.15.3.1 External Signals

The following table describes the external signals of SPI. The MOSI and MISO are bidirectional I/O, when SPI is as a master device, the CLK and CS are the output pin; when SPI is as a slave device, the CLK and CS are the input pin. When using SPI, the corresponding PADs are selected as SPI function via section 8.5 GPIO.

**Table 8-41 SPI External Signals**

| Signal Name <sup>[1]</sup> | Description                                                                                                                                                                                              | Type |
|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| SPI0-CS[1:0]               | SPI0 Chip Select Signal, Low Active                                                                                                                                                                      | I/O  |
| SPI0-CLK                   | SPI0 Clock Signal<br>Provides serial interface timing.                                                                                                                                                   | I/O  |
| SPI0-MOSI                  | SPI0 Master Data Out, Slave Data In                                                                                                                                                                      | I/O  |
| SPI0-MISO                  | SPI0 Master Data In, Slave Data Out                                                                                                                                                                      | I/O  |
| SPI0-WP                    | SPI0 Write Protect, Low Active<br>Protects the memory area against all program or erase instructions.<br>It also can be used for serial data input and output for SPI Quad Input or Quad Output mode.    | I/O  |
| SPI0-HOLD                  | SPI0 Hold Signal<br>Pauses any serial communication with the device without deselecting or resetting it.<br>It also can be used for serial data input and output for SPI Quad Input or Quad Output mode. | I/O  |
| SPI2-CS0                   | SPI2 Chip Select Signal, Low Active                                                                                                                                                                      | I/O  |
| SPI2-CLK                   | SPI2 Clock Signal<br>Provides serial interface timing.                                                                                                                                                   | I/O  |
| SPI2-MOSI                  | SPI2 Master Data Out, Slave Data In                                                                                                                                                                      | I/O  |
| SPI2-MISO                  | SPI2 Master Data In, Slave Data Out                                                                                                                                                                      | I/O  |
| S-SPI0-CS0                 | S-SPI Chip Select Signal, Low Active                                                                                                                                                                     | I/O  |
| S-SPI0-CLK                 | S-SPI Clock Signal<br>Provides serial interface timing.                                                                                                                                                  | I/O  |
| S-SPI0-MOSI                | S-SPI Master Data Out, Slave Data In                                                                                                                                                                     | I/O  |
| S-SPI0-MISO                | S-SPI Master Data In, Slave Data Out                                                                                                                                                                     | I/O  |

#### 8.15.3.2 Clock Sources

Every SPI controller gets 5 different clock sources, users can select one of them to make SPI clock source. The following table describes the clock sources for SPI. For more details on the clock setting, configuration, and gating information, see section 2.5 Clock Controller Unit (CCU) and section 2.11 Power Reset Clock Management (PRCM).

Table 8-42 SPI Clock Sources

| SPI        | Clock Sources | Description                                      | Clock Module |
|------------|---------------|--------------------------------------------------|--------------|
| SPI0, SPI2 | HOSC          | 24 MHz Crystal                                   | CCU          |
|            | PERI0_200M    | Peripheral Clock, default value is 200 MHz.      |              |
|            | PERI0_300M    | Peripheral Clock, default value is 300 MHz.      |              |
|            | PERI1_200M    | Peripheral Clock, default value is 200 MHz.      |              |
|            | PERI1_300M    | Peripheral Clock, default value is 300 MHz.      |              |
| S_SPI0     | DCXO24M       | 24 MHz Crystal                                   | PRCM         |
|            | PERIPLL_DIV   | Peripheral Clock, default value is 200 MHz.      |              |
|            | PERI0_300M    | Peripheral Clock, default value is 300 MHz.      |              |
|            | PERI1_300M    | Peripheral Clock, default value is 300 MHz.      |              |
|            | AUDIO1PLL4X   | Audio system clock, the defult value is 768 MHz. |              |

### 8.15.3.3 Typical Application

The following figure shows the application block diagram when the SPI master device is connected to a slave device.

Figure 8-64 SPI Application Block Diagram



### 8.15.3.4 SPI Transmit Format

The SPI supports 4 different formats for data transfer. The software can select one of the four modes in which the SPI works by setting the bit1 (Polarity) and bit0 (Phase) of [SPI\\_TCR](#) (Offset: 0x0008). The SPI controller master uses the SPI\_SCLK signal to transfer data in and out of the shift register. Data is clocked using any one of four programmable clock phase and polarity combinations.

The CPOL ([SPI\\_TCR](#) [1]) defines the polarity of the clock signal (SPI\_SCLK). The SPI\_SCLK is a high level when CPOL is '1' and it is a low level when CPOL is '0'. The CPHA ([SPI\\_TCR](#) [0]) decides whether the leading edge of SPI\_SCLK is used to setup or sample data. The leading edge is used

to setup data when CPHA is '1', and sample data when CPHA is '0'. The following table lists the four modes.

**Table 8-43 SPI Transmit Format**

| Mode  | Polarity (CPOL) | Phase (CPHA) | Leading Edge               | Trailing Edge              |
|-------|-----------------|--------------|----------------------------|----------------------------|
| Mode0 | 0               | 0            | Sample on the rising edge  | Setup on the falling edge  |
| Mode1 | 0               | 1            | Setup on the rising edge   | Sample on the falling edge |
| Mode2 | 1               | 0            | Sample on the falling edge | Setup on the rising edge   |
| Mode3 | 1               | 1            | Setup on the falling edge  | Sample on the rising edge  |

The following figures describe four waveform for SPI\_SCLK.

**Figure 8-65 SPI Phase 0 Timing Diagram**



**Figure 8-66 SPI Phase 1 Timing Diagram**



### 8.15.3.5 SPI 3-Wire Mode

The SPI 3-wire mode is only valid when the SPI controller work in master mode, and is selected when the Work Mode Select bit ([SPI\\_BATCR \[1:0\]](#)) is equal to 0x2. And in the 3-wire mode, the

input data and the output data use the same single data line. The following figure describes the 3-wire mode.

**Figure 8-67 SPI 3-Wire Mode**



#### 8.15.3.6 SPI Dual-Input/Dual-Output and Dual I/O Mode

The dual read mode (SPI x2) is selected when the DRM is set in [SPI\\_BCC](#) (Offset: 0x0038) [28]. Using the dual mode allows data to be transferred to or from the device at double the rate of standard single mode, the data can be read at fast speed using two data bits (MOSI and MISO) at a time. The following figure describes the dual-input/dual-output SPI and the dual I/O SPI.

**Figure 8-68 SPI Dual-Input/Dual-Output Mode**



In the dual-input/dual-output SPI mode, the command, address, and the dummy bytes output in a unit of a single bit in serial mode through the SPI\_MOSI line, only the data bytes are output (write) and input (read) in a unit of dual bits through the SPI\_MOSI and SPI\_MISO.

Figure 8-69 SPI Dual I/O Mode



In the dual I/O SPI mode, only the command bytes output in a unit of a single bit in serial mode through the SPI\_MOSI line. The address bytes and the dummy bytes output in a unit of dual bits through the SPI\_MOSI and SPI\_MISO. And the data bytes output (write) and input (read) in a unit of dual bits through the SPI\_MOSI and SPI\_MISO.

#### 8.15.3.7 SPI Quad-Input/Quad-Output Mode

The quad read mode (SPI x4) is selected when the Quad\_EN is set in [SPI\\_BCC](#) (Offset: 0x0038) [29]. Using the quad mode allows data to be transferred to or from the device at 4 times the rate of standard single mode, the data can be read at fast speed using four data bits (MOSI, MISO, IO2 (WP#) and IO3 (HOLD#)) at the same time. The following figure describes the quad-input/quad-output SPI.

Figure 8-70 SPI Quad-Input/Quad-Output Mode



In the quad-input/quad-output SPI mode, the command, address, and the dummy bytes output in a unit of a single bit in serial mode through SPI\_MOSI line. Only the data bytes output (write) and input (read) in a unit of quad bits through the SPI\_MOSI, SPI\_MISO, SPI\_WP#, and SPI\_HOLD#.

#### 8.15.3.8 Transmission/Reception Bursts in Master Mode

In SPI master mode, the transmission and reception bursts (byte in unit) are configured before the SPI transfers serial data between the processor and external device. The transmission bursts are written in [MWTC](#) (bit [23:0]) of the [SPI Master Transmit Counter Register](#). The transmission bursts in single mode before automatically sending dummy bursts are written in STC (bit [23:0]) of the [SPI Master Burst Control Counter Register](#). For dummy data, the SPI controller can automatically send before receiving by writing [DBC](#) (bit [27:24]) in the [SPI Master Burst Control Counter Register](#). If users do not use the SPI controller to send dummy data automatically, then the dummy bursts are used as the transmission counters to write together in [MWTC](#) (bit [23:0]) of the [SPI Master Transmit Counter Register](#). In master mode, the total burst numbers are written in [MBC](#) (bit [23:0]) of the [SPI Master Burst Counter Register](#). When all transmission and reception bursts are transferred, the SPI controller will send a completed interrupt, at the same time, the SPI controller will clear [DBC](#), [MWTC](#), and [MBC](#).

#### 8.15.3.9 SPI Sample Mode and Run Clock Configuration

The SPI controller runs at 3 kHz–100 MHz at its interface to external SPI devices. The internal SPI clock should run at the same frequency as the outgoing clock in the master mode. The SPI clock is selected from different clock sources, the SPI must configure different work mode. There are three work modes: normal sample mode, delay half-cycle sample mode, delay one-cycle sample mode. Delay half-cycle sample mode is the default mode of the SPI controller. When the SPI runs at 40 MHz or below 40 MHz, the SPI can work at normal sample mode or delay half-cycle sample mode. When the SPI runs over 80 MHz, setting the SDC bit in the [SPI Transfer Control Register](#) to '1' makes the internal read sample point with a half-cycle delay of SPI\_CLK, which is used in high speed read operation to reduce the error caused by the time delay of SPI\_CLK between master and slave. The following tables show the different configurations of the SPI sample mode.

Table 8-44 SPI Old Sample Mode and Run Clock

| SPI Sample Mode         | SDM(bit13) | SDC(bit11) | Run Clock |
|-------------------------|------------|------------|-----------|
| normal sample           | 1          | 0          | <=24 MHz  |
| delay half cycle sample | 0          | 0          | <=40 MHz  |
| delay one cycle sample  | 0          | 1          | >=80 MHz  |

**CAUTION**

The remaining spectrum is not recommended. Because when the output delay of SPI flash (refer to the datasheet of the manufacturer for the specific delay time) is the same with the half-cycle time of SPI working clock, the variable edge of the output data for the device bumps into the clock sampling edge of the controller, so setting 1 cycle of sampling delay would cause stability problem.

**Table 8-45 SPI New Sample Mode**

| SPI Sample Mode         | SDM (bit13) | SDC (bit11) | SDC1 (bit15) |
|-------------------------|-------------|-------------|--------------|
| normal sample           | 1           | 0           | 0            |
| delay half cycle sample | 0           | 0           | 0            |
| delay one cycle sample  | 0           | 1           | 0            |
| delay 1.5 cycle sample  | 1           | 1           | 0            |
| delay 2 cycle sample    | 1           | 0           | 1            |
| delay 2.5 cycle sample  | 0           | 0           | 1            |
| delay 3 cycle sample    | 0           | 1           | 1            |

#### 8.15.3.10 SPI Error Conditions

If any error conditions occur, the hardware will set the corresponding status bits in the [SPI Interrupt Status Register](#) (Offset: 0x0014) and stop the transfer. For the SPI controller, the following error scenarios can happen.

- TX\_FIFO Underrun

The TX\_FIFO underrun happens when the CPU/DMA reads data from TX FIFO when it is empty. In the case, the SPI controller will end the transaction and flag the error bit along with the TF\_UDF bit in the [SPI Interrupt Status Register](#) (Offset: 0x0014). The SPI controller will generate an interrupt if interrupts are enabled. The software has to clear the error bit and the TF\_UDF bit. To start a new transaction, the software has to reset the FIFO by writing to the SRST (soft reset) bit in the [SPI Global Control Register](#) (Offset: 0x0004).

- TX\_FIFO Overflow

The TX\_FIFO overflow happens when the CPU/DMA writes data into the TX FIFO when it is full. In the case, the SPI controller will end the transaction and flag the error bit along with the TF\_OVF bit in the [SPI Interrupt Status Register](#) (Offset: 0x0014). The SPI controller will generate an interrupt if interrupts are enabled. The software has to clear the error bit and the TF\_OVF bit. To start a new transaction, the software has to reset the FIFO by writing to the SRST (soft reset) bit in the [SPI Global Control Register](#) (Offset: 0x0004).

- RX\_FIFO Underrun

The RX\_FIFO underrun happens when the CPU/DMA reads data from RX FIFO when it is empty. In the case, the SPI controller will end the transaction and flag the error bit along with the RF\_UDF

bit in the [SPI Interrupt Status Register](#) (Offset: 0x0014). The SPI controller will generate an interrupt if interrupts are enabled. The software has to clear the error bit and the RF\_UDF bit. To start a new transaction, the software has to reset the FIFO by writing to the SRST (soft reset) bit in the [SPI Global Control Register](#) (Offset: 0x0004).

- RX\_FIFO Overflow

The RX\_FIFO overflow happens when the CPU/DMA writes data into the RX FIFO when it is full. In the case, the SPI controller will end the transaction and flag the error bit along with the RF\_OVF bit in the [SPI Interrupt Status Register](#) (Offset: 0x0014). The SPI controller will generate an interrupt if interrupts are enabled. The software has to clear the error bit and the RF\_OVF bit. To start a new transaction, the software has to reset the FIFO by writing to the SRST (soft reset) bit in the [SPI Global Control Register](#) (Offset: 0x0004).

## 8.15.4 Programming Guidelines

### 8.15.4.1 Writing/Reading Data Process

The SPI transfers serial data between the processor and the external device. The CPU mode and DMA mode are the two main operational modes for SPI. For each SPI, the data is simultaneously transmitted (shifted out serially) and received (shifted in serially). The SPI has 2 channels, including the TX channel and RX channel. The TX channel has the path from TX FIFO to the external device. The RX channel has the path from the external device to RX FIFO.

**Write Data:** The CPU or DMA must write data on the [SPI\\_TXD](#) (Offset: 0x0200), the data on the register are automatically moved to TX FIFO.

**Read Data:** To read data from RX FIFO, the CPU or DMA must access the [SPI\\_RXD](#) (Offset: 0x0300) and the data are automatically sent to the [SPI\\_RXD](#) (Offset: 0x0300).

In CPU or DMA mode, the SPI sends a completed interrupt ([SPI\\_ISR\[TC\]](#)) to the processor after each transmission is complete.

## CPU Mode

Figure 8-71 SPI Write/Read Data in CPU Mode



## DMA Mode

Figure 8-7 SPI Write/Read Data in DMA Mode



### 8.15.5 Register List

| Module Name | Base Address |
|-------------|--------------|
| SPI0        | 0x0402 5000  |
| SPI2        | 0x0402 7000  |
| S_SPI0      | 0x0709 2000  |

| Register Name     | Offset | Description                                 |
|-------------------|--------|---------------------------------------------|
| SPI_GCR           | 0x0004 | SPI Global Control Register                 |
| SPI_TCR           | 0x0008 | SPI Transfer Control register               |
| SPI_IER           | 0x0010 | SPI Interrupt Control register              |
| SPI_ISR           | 0x0014 | SPI Interrupt Status register               |
| SPI_FCR           | 0x0018 | SPI FIFO Control register                   |
| SPI_FSR           | 0x001C | SPI FIFO Status register                    |
| SPI_WCR           | 0x0020 | SPI Wait Clock Counter register             |
| SPI_SAMP_DL       | 0x0028 | SPI Sample Delay Control Register           |
| SPI_MBC           | 0x0030 | SPI Master Burst Counter register           |
| SPI_MTC           | 0x0034 | SPI Master Transmit Counter Register        |
| SPI_BCC           | 0x0038 | SPI Master Burst Control Counter register   |
| SPI_BATCR         | 0x0040 | SPI Bit-Aligned Transfer Configure Register |
| SPI_TBR           | 0x0048 | SPI TX Bit Register                         |
| SPI_RBR           | 0x004C | SPI RX Bit Register                         |
| SPI_NDMA_MODE_CTL | 0x0088 | SPI Normal DMA Mode Control Register        |
| SPI_TXD           | 0x0200 | SPI TX Data register                        |
| SPI_RXD           | 0x0300 | SPI RX Data register                        |
| SPI_BSR           | 0x0400 | SPI BUF Status register                     |

### 8.15.6 Register Description

#### 8.15.6.1 0x0004 SPI Global Control Register (Default Value: 0x0000\_0080)

| Offset: 0x0004 |            |             | Register Name: SPI_GCR                                                                                                                                      |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                 |
| 31             | R/WAC      | 0x0         | SRST<br>Soft reset<br>Write '1' to this bit will clear the SPI controller, and auto clear to '0' when reset operation completes<br>Write '0' has no effect. |
| 30:8           | /          | /           | /                                                                                                                                                           |
| 7              | R/W        | 0x1         | TP_EN<br>Transmit Pause Enable                                                                                                                              |

| Offset: 0x0004 |            |             | Register Name: SPI_GCR                                                                                                                                                                                                                                       |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                  |
|                |            |             | In master mode, it is used to control transmit state machine to stop smart burst sending when RX FIFO is full.<br>1: stop transmit data when RXFIFO full<br>0: normal operation, ignore RXFIFO status<br><b>Note: This bit cannot be written when XCH=1.</b> |
| 6:3            | /          | /           | /                                                                                                                                                                                                                                                            |
| 2              | R/W        | 0x0         | MODE_SEL<br>Sample Timing Mode Select<br>0: Old mode of Sample Timing<br>1: New mode of Sample Timing<br><b>Note: This bit cannot be written when XCH=1.</b>                                                                                                 |
| 1              | R/W        | 0x0         | MODE<br>SPI Function Mode Select<br>0: Slave Mode<br>1: Master Mode<br><b>Note: This bit cannot be written when XCH=1.</b>                                                                                                                                   |
| 0              | R/W        | 0x0         | EN<br>SPI Module Enable Control<br>0: Disable<br>1: Enable<br><b>Note: After transforming from bit_mode to byte_mode, it must Enable the SPI Module again.</b>                                                                                               |

#### 8.15.6.2 0x0008 SPI Transfer Control Register (Default Value: 0x0000\_0087)

| Offset: 0x0008 |            |             | Register Name: SPI_TCR                                                                                                                                                                                                                                                                                                                                                         |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                    |
| 31             | R/WAC      | 0x0         | XCH<br>Exchange Burst<br>In master mode it is used to start SPI burst<br>0: Idle<br>1: Initiates exchange.<br>Write “1” to this bit will start the SPI burst, and will auto clear after finishing the bursts transfer specified by BC. Write “1” to SRST will also clear this bit. Write ‘0’ to this bit has no effect.<br><b>Note: This bit cannot be written when XCH=1.</b> |
| 30:16          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                              |
| 15             | R/W        | 0x0         | SDC1<br>Master Sample Data Control register1                                                                                                                                                                                                                                                                                                                                   |

| Offset: 0x0008 |            |             | Register Name: SPI_TCR                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                |            |             | <p>Set this bit to '1' to make the internal read sample point with a delay of half cycle of SPI_CLK. It is used in high speed read operation to reduce the error caused by the time delay of SPI_CLK propagating between master and slave.</p> <p>0: Normal operation, do not delay internal read sample point<br/>1: Delay internal read sample point</p> <p><b>Note:</b> This bit cannot be written when XCH=1.</p>                                       |
| 14             | R/W        | 0x0         | <p>SDDM<br/>Sending Data Delay Mode<br/>0: Normal sending<br/>1: Delay sending</p> <p>Set the bit to "1" to make the data that should be sent with a delay of half cycle of SPI_CLK in dual I/O mode for SPI mode 0.</p>                                                                                                                                                                                                                                    |
| 13             | R/W        | 0x0         | <p>SDM<br/>Master Sample Data Mode<br/>1 - Normal Sample Mode<br/>0 - Delay Sample Mode</p> <p>In Normal Sample Mode, SPI master samples the data at the correct edge for each SPI mode;<br/>In Delay Sample Mode, SPI master samples data at the edge that is half cycle delayed by the correct edge defined in respective SPI mode.</p>                                                                                                                   |
| 12             | R/W        | 0x0         | <p>FBS<br/>First Transmit Bit Select<br/>0: MSB first<br/>1: LSB first</p> <p><b>Note:</b> Can't be written when XCH=1.</p>                                                                                                                                                                                                                                                                                                                                 |
| 11             | R/W        | 0x0         | <p>SDC<br/>Master Sample Data Control<br/>Set this bit to '1' to make the internal read sample point with a delay of half cycle of SPI_CLK. It is used in high speed read operation to reduce the error caused by the time delay of SPI_CLK propagating between master and slave.</p> <p>0: Normal operation, do not delay internal read sample point<br/>1: Delay internal read sample point</p> <p><b>Note:</b> This bit can't be written when XCH=1.</p> |

| Offset: 0x0008 |            |             | Register Name: SPI_TCR                                                                                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                 |
| 10             | R/W        | 0x0         | <p>RPSM<br/>Rapids mode select<br/>Select Rapids mode for high speed write.<br/>0: normal write mode<br/>1: rapids write mode<br/><b>Note:</b> Can't be written when XCH=1.</p>                                                                                                                                                             |
| 9              | R/W        | 0x0         | <p>DDB<br/>Dummy Burst Type<br/>0: The bit value of dummy SPI burst is zero<br/>1: The bit value of dummy SPI burst is one<br/><b>Note:</b> This bit can't be written when XCH=1.</p>                                                                                                                                                       |
| 8              | R/W        | 0x0         | <p>DHB<br/>Discard Hash Burst<br/>In master mode it controls whether discarding unused SPI bursts<br/>0: Receiving all SPI bursts in BC period<br/>1: Discard unused SPI bursts, only fetching the SPI bursts during dummy burst period. The bursts number is specified by TC.<br/><b>Note:</b> This bit can't be written when XCH=1.</p>   |
| 7              | R/W        | 0x1         | <p>SS_LEVEL<br/>When control SS signal manually (SPI_CTRL_REG.SS_CTRL==1), set this bit to '1' or '0' to control the level of SS signal.<br/>0: set SS to low<br/>1: set SS to high<br/><b>Note:</b> This bit can't be written when XCH=1.</p>                                                                                              |
| 6              | R/W        | 0x0         | <p>SS_OWNER<br/>SS Output Owner Select<br/>Usually, controller sends SS signal automatically with data together. When this bit is set to 1, software must manually write SPI_CTL_REG.SS_LEVEL to 1 or 0 to control the level of SS signal.<br/>0: SPI controller<br/>1: Software<br/><b>Note:</b> This bit can't be written when XCH=1.</p> |
| 5:4            | R/W        | 0x0         | <p>SS_SEL<br/>SPI Chip Select<br/>Select one of four external SPI Master/Slave Devices<br/>00: SPI_SS0 will be asserted<br/>01: SPI_SS1 will be asserted</p>                                                                                                                                                                                |

| Offset: 0x0008 |            |             | Register Name: SPI_TCR                                                                                                                                                                                                                                                      |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                 |
|                |            |             | 10: SPI_SS2 will be asserted<br>11: SPI_SS3 will be asserted<br><b>Note: This bit can't be written when XCH=1.</b>                                                                                                                                                          |
| 3              | R/W        | 0x0         | <b>SSCTL</b><br>In master mode, this bit selects the output wave form for the SPI_SSx signal. Only valid when SS_OWNER = 0.<br>0: SPI_SSx remains asserted between SPI bursts<br>1: Negate SPI_SSx between SPI bursts<br><b>Note: This bit can't be written when XCH=1.</b> |
| 2              | R/W        | 0x1         | <b>SPOL</b><br>SPI Chip Select Signal Polarity Control<br>0: Active high polarity (0 = Idle)<br>1: Active low polarity (1 = Idle)<br><b>Note: This bit can't be written when XCH=1.</b>                                                                                     |
| 1              | R/W        | 0x1         | <b>CPOL</b><br>SPI Clock Polarity Control<br>0: Active high polarity (0 = Idle)<br>1: Active low polarity (1 = Idle)<br><b>Note: This bit can't be written when XCH=1.</b>                                                                                                  |
| 0              | R/W        | 0x1         | <b>CPHA</b><br>SPI Clock/Data Phase Control<br>0: Phase 0 (Leading edge for sample data)<br>1: Phase 1 (Leading edge for setup data)<br><b>Note: This bit can't be written when XCH=1.</b>                                                                                  |

#### 8.15.6.3 0x0010 SPI Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0010 |            |             | Register Name: SPI_IER                                                                                                            |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                       |
| 31:14          | /          | /           | /                                                                                                                                 |
| 13             | R/W        | 0x0         | <b>SS_INT_EN</b><br>SSI Interrupt Enable<br>Chip Select Signal (SSx) from valid state to invalid state<br>0: Disable<br>1: Enable |
| 12             | R/W        | 0x0         | <b>TC_INT_EN</b><br>Transfer Completed Interrupt Enable<br>0: Disable<br>1: Enable                                                |

| Offset: 0x0010 |            |             | Register Name: SPI_IER                                                             |
|----------------|------------|-------------|------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                        |
| 11             | R/W        | 0x0         | TF_UDR_INT_EN<br>TXFIFO under run Interrupt Enable<br>0: Disable<br>1: Enable      |
| 10             | R/W        | 0x0         | TF_OVF_INT_EN<br>TX FIFO Overflow Interrupt Enable<br>0: Disable<br>1: Enable      |
| 9              | R/W        | 0x0         | RF_UDR_INT_EN<br>RXFIFO under run Interrupt Enable<br>0: Disable<br>1: Enable      |
| 8              | R/W        | 0x0         | RF_OVF_INT_EN<br>RX FIFO Overflow Interrupt Enable<br>0: Disable<br>1: Enable      |
| 7              | /          | /           | /                                                                                  |
| 6              | R/W        | 0x0         | TF_FUL_INT_EN<br>TX FIFO Full Interrupt Enable<br>0: Disable<br>1: Enable          |
| 5              | R/W        | 0x0         | TX_EMP_INT_EN<br>TX FIFO Empty Interrupt Enable<br>0: Disable<br>1: Enable         |
| 4              | R/W        | 0x0         | TX_ERQ_INT_EN<br>TX FIFO Empty Request Interrupt Enable<br>0: Disable<br>1: Enable |
| 3              | /          | /           | /                                                                                  |
| 2              | R/W        | 0x0         | RF_FUL_INT_EN<br>RX FIFO Full Interrupt Enable<br>0: Disable<br>1: Enable          |
| 1              | R/W        | 0x0         | RX_EMP_INT_EN<br>RX FIFO Empty Interrupt Enable<br>0: Disable<br>1: Enable         |
| 0              | R/W        | 0x0         | RF_RDY_INT_EN<br>RX FIFO Ready Request Interrupt Enable<br>0: Disable              |

| Offset: 0x0010 |            |             | Register Name: SPI_IER |
|----------------|------------|-------------|------------------------|
| Bit            | Read/Write | Default/Hex | Description            |
|                |            |             | 1: Enable              |

#### 8.15.6.4 0x0014 SPI Interrupt Status Register (Default Value: 0x0000\_0032)

| Offset: 0x0014 |            |             | Register Name: SPI_ISR                                                                                                                                                                                                                                                                                                                                     |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                |
| 31:14          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                          |
| 13             | R/W1C      | 0x0         | SSI<br>SS Invalid Interrupt<br>When SSI is 1, it indicates that SS has changed from valid state to invalid state. Writing 1 to this bit clears it.                                                                                                                                                                                                         |
| 12             | R/W1C      | 0x0         | TC<br>Transfer Completed<br>In master mode, it indicates that all bursts specified by BC has been exchanged. In other condition, when set, this bit indicates that all the data in TXFIFO has been loaded in the Shift register, and the Shift register has shifted out all the bits. Writing 1 to this bit clears it.<br>0: Busy<br>1: Transfer Completed |
| 11             | R/W1C      | 0x0         | TF_UDF<br>TXFIFO under run<br>This bit is set when if the TXFIFO is underrun. Writing 1 to this bit clears it.<br>0: TXFIFO is not underrun<br>1: TXFIFO is underrun                                                                                                                                                                                       |
| 10             | R/W1C      | 0x0         | TF_OVF<br>TXFIFO Overflow<br>This bit is set when if the TXFIFO is overflow. Writing 1 to this bit clears it.<br>0: TXFIFO is not overflow<br>1: TXFIFO is overflowed                                                                                                                                                                                      |
| 9              | R/W1C      | 0x0         | RX_UDF<br>RXFIFO Underrun<br>When set, this bit indicates that RXFIFO has underrun. Writing 1 to this bit clears it.                                                                                                                                                                                                                                       |
| 8              | R/W1C      | 0x0         | RX_OVF<br>RXFIFO Overflow<br>When set, this bit indicates that RXFIFO has                                                                                                                                                                                                                                                                                  |

| Offset: 0x0014 |            |             | Register Name: SPI_ISR                                                                                                                                                                                               |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                          |
|                |            |             | overflowed. Writing 1 to this bit clears it.<br>0: RXFIFO is available.<br>1: RXFIFO has overflowed.                                                                                                                 |
| 7              | /          | /           | /                                                                                                                                                                                                                    |
| 6              | R/W1C      | 0x0         | TX_FULL<br>TXFIFO Full<br>This bit is set when if the TXFIFO is full. Writing 1 to this bit clears it.<br>0: TXFIFO is not Full<br>1: TXFIFO is Full                                                                 |
| 5              | R/W1C      | 0x1         | TX_EMP<br>TXFIFO Empty<br>This bit is set if the TXFIFO is empty. Writing 1 to this bit clears it.<br>0: TXFIFO contains one or more words.<br>1: TXFIFO is empty                                                    |
| 4              | R/W1C      | 0x1         | TX_READY<br>TXFIFO Ready<br>0: TX_WL > TX_TRIG_LEVEL<br>1: TX_WL <= TX_TRIG_LEVEL<br>This bit is set any time if TX_WL <= TX_TRIG_LEVEL. Writing "1" to this bit clears it. Where TX_WL is the water level of RXFIFO |
| 3              | /          | /           | /                                                                                                                                                                                                                    |
| 2              | R/W1C      | 0x0         | RX_FULL<br>RXFIFO Full<br>This bit is set when the RXFIFO is full. Writing 1 to this bit clears it.<br>0: Not Full<br>1: Full                                                                                        |
| 1              | R/W1C      | 0x1         | RX_EMP<br>RXFIFO Empty<br>This bit is set when the RXFIFO is empty. Writing 1 to this bit clears it.<br>0: Not empty<br>1: empty                                                                                     |
| 0              | R/W1C      | 0x0         | RX_RDY<br>RXFIFO Ready<br>0: RX_WL <= RX_TRIG_LEVEL<br>1: RX_WL > RX_TRIG_LEVEL<br>This bit is set any time if RX_WL > RX_TRIG_LEVEL.                                                                                |

| Offset: 0x0014 |            |             | Register Name: SPI_ISR                                                       |
|----------------|------------|-------------|------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                  |
|                |            |             | Writing “1” to this bit clears it. Where RX_WL is the water level of RXFIFO. |

#### 8.15.6.5 0x0018 SPI FIFO Control Register (Default Value: 0x0040\_0001)

| Offset: 0x0018 |            |             | Register Name: SPI_FCR                                                                                                                                                                                                                                                                                                                        |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                   |
| 31             | R/WAC      | 0x0         | <p>TX_FIFO_RST<br/>TX FIFO Reset<br/>Write ‘1’ to this bit will reset the control portion of the TX FIFO and auto clear to ‘0’ when completing reset operation, write to ‘0’ has no effect.</p>                                                                                                                                               |
| 30             | R/W        | 0x0         | <p>TF_TEST_ENB<br/>TX Test Mode Enable<br/>0: disable<br/>1: enable<br/>In normal mode, TX FIFO can only be read by SPI controller, write ‘1’ to this bit will switch TX FIFO read and write function to AHB bus. This bit is used to test the TX FIFO, don’t set in normal operation and don’t set RF_TEST and TF_TEST at the same time.</p> |
| 29:25          | /          | /           | /                                                                                                                                                                                                                                                                                                                                             |
| 24             | R/W        | 0x0         | <p>TF_DRQ_EN<br/>TX FIFO DMA Request Enable<br/>0: Disable<br/>1: Enable</p>                                                                                                                                                                                                                                                                  |
| 23:16          | R/W        | 0x40        | <p>TX_TRIG_LEVEL<br/>TX FIFO Empty Request Trigger Level</p>                                                                                                                                                                                                                                                                                  |
| 15             | R/WAC      | 0x0         | <p>RF_RST<br/>RXFIFO Reset<br/>Write ‘1’ to this bit will reset the control portion of the receiver FIFO, and auto clear to ‘0’ when completing reset operation, write ‘0’ to this bit has no effect.</p>                                                                                                                                     |
| 14             | R/W        | 0x0         | <p>RF_TEST<br/>RX Test Mode Enable<br/>0: Disable<br/>1: Enable<br/>In normal mode, RX FIFO can only be written by SPI controller, write ‘1’ to this bit will switch RX FIFO read and write function to AHB bus. This bit is used to test the RX FIFO, don’t set in normal operation and don’t</p>                                            |

| Offset: 0x0018 |            |             | Register Name: SPI_FCR                                                                                                                                                                         |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                    |
|                |            |             | set RF_TEST and TF_TEST at the same time.                                                                                                                                                      |
| 13:9           | /          | /           | /                                                                                                                                                                                              |
| 8              | R/W        | 0x0         | RF_DRQ_EN<br>RX FIFO DMA Request Enable<br>0: Disable<br>1: Enable                                                                                                                             |
| 7:0            | R/W        | 0x1         | RX_TRIG_LEVEL<br>RX FIFO Ready Request Trigger Level<br>CAUTION: Whether in CPU mode or in DMA mode,<br>trigger level should be set properly that actual data<br>amount reaches trigger level. |

#### 8.15.6.6 0x001C SPI FIFO Status Register (Default Value: 0x0000\_0000)

| Offset: 0x001C |            |             | Register Name: SPI_FSR                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                             |
| 31             | R          | 0x0         | TB_WR<br>TX FIFO Write Buffer Write Enable                                                                                                                                                                                                                                              |
| 30:24          | /          | /           | /                                                                                                                                                                                                                                                                                       |
| 23:16          | R          | 0x0         | TF_CNT<br>TX FIFO Counter<br>These bits indicate the number of words in TX FIFO<br>0: 0 byte in TX FIFO<br>1: 1 byte in TX FIFO<br>...<br>64: 64 bytes in TX FIFO<br>other: Reserved                                                                                                    |
| 15             | R          | 0x0         | RB_WR<br>RX FIFO Read Buffer Write Enable                                                                                                                                                                                                                                               |
| 14:8           | /          | /           | /                                                                                                                                                                                                                                                                                       |
| 7:0            | R          | 0x0         | RF_CNT<br>RX FIFO Counter<br>These bits indicate the number of words in RX FIFO +<br>RX BUFFER<br>0: 0 byte in RX FIFO & RX BUFFER<br>1: 1 byte in RX FIFO & RX BUFFER<br>...<br>64: 64 bytes in RX FIFO & RX BUFFER<br>...<br>192: 192 bytes in RX FIFO & RX BUFFER<br>other: Reserved |

#### 8.15.6.7 0x0020 SPI Wait Clock Counter Register (Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: SPI_WCR                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                               |
| 31:20          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 19:16          | R/W        | 0x0         | <p>SWC<br/>Dual mode direction switch waits clock counter (for master mode only).<br/>0: No wait states inserted<br/>n: n SPI_SCLK wait states inserted<br/>Note: These bits control the number of wait states to be inserted before start dual data transfer in dual SPI mode. The SPI module counts SPI_SCLK by SWC for delaying next word data transfer.</p> <p><b>Note: This bit can't be written when XCH=1.</b></p> |
| 15:0           | R/W        | 0x0         | <p>WCC<br/>Wait Clock Counter (In Master mode)<br/>These bits control the number of wait states to be inserted in data transfers. The SPI module counts SPI_SCLK by WCC for delaying next word data transfer.<br/>0: No wait states inserted<br/>N: N SPI_SCLK wait states inserted<br/>Note:<br/>1. Can't be written when XCH=1;</p>                                                                                     |

#### 8.15.6.8 0x0028 SPI Sample Delay Control Register (Default Value: 0x0000\_2000)

| Offset: 0x0028 |            |             | Register Name: SPI_SAMP_DL                                                                                                                                                                                                                     |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                    |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                              |
| 7              | R/W        | 0x0         | <p>SAMP_DL_SW_EN<br/>Sample Delay Software Enable<br/>When set, enable sample delay specified at SAMP_DL_SW</p>                                                                                                                                |
| 6              | /          | /           | /                                                                                                                                                                                                                                              |
| 5:0            | R/W        | 0x0         | <p>SAMP_DL_SW<br/>Sample Delay Software<br/>The relative delay between clock line and command line, data lines.<br/>It can be determined according to the value of SAMP_DL, the cycle of card clock and device's input timing requirement.</p> |

#### 8.15.6.9 0x0030 SPI Master Burst Counter Register (Default Value: 0x0000\_0000)

| Offset: 0x0030 |            |             | Register Name: SPI_MBC                                                                                                                                                                                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                           |
| 31:24          | /          | /           | /                                                                                                                                                                                                                                                                     |
| 23:0           | R/W        | 0x0         | <p>MBC<br/>Master Burst Counter<br/>In master mode, this field specifies the total burst number.<br/>0: 0 burst<br/>1: 1 burst<br/>...<br/>N: N bursts<br/>Note: (i) Can't be written when XCH=1; (ii) Total transfer data, include the TXD, RXD and dummy burst.</p> |

#### 8.15.6.10 0x0034 SPI Master Transmit Counter Register (Default Value: 0x0000\_0000)

| Offset: 0x0034 |            |             | Register Name: SPI_MTC                                                                                                                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                     |
| 31:24          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                               |
| 23:0           | R/W        | 0x0         | <p>MWTC<br/>Master Write Transmit Counter<br/>In master mode, this field specifies the burst number that should be sent to TXFIFO before automatically sending dummy burst. For saving bus bandwidth, the dummy burst (all zero bits or all one bits) is sent by SPI Controller automatically.<br/>0: 0 burst<br/>1: 1 burst<br/>...<br/>N: N bursts<br/>Note: Can't be written when XCH=1.</p> |

#### 8.15.6.11 0x0038 SPI Master Burst Control Counter Register (Default Value: 0x0000\_0000)

| Offset: 0x0038 |            |             | Register Name: SPI_BCC                                   |
|----------------|------------|-------------|----------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                              |
| 31:30          | /          | /           | /                                                        |
| 29             | R/W        | 0x0         | <p>Quad_EN<br/>Quad_Mode_EN<br/>0: Quad mode disable</p> |

| Offset: 0x0038 |            |             | Register Name: SPI_BCC                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                            |
|                |            |             | <p>1: Quad mode enable<br/> <b>Note:</b></p> <ul style="list-style-type: none"> <li>• Can't be written when XCH=1;</li> <li>• Quad mode includes Quad-Input and Quad-Output.</li> </ul>                                                                                                                                                                |
| 28             | R/W        | 0x0         | <p>DRM<br/> Master Dual Mode RX Enable<br/> 0: RX use single-bit mode<br/> 1: RX use dual mode<br/> <b>Note:</b></p> <ul style="list-style-type: none"> <li>• Can't be written when XCH=1;</li> <li>• It is only valid when Quad_Mode_EN=0.</li> </ul>                                                                                                 |
| 27:24          | R/W        | 0x0         | <p>DBC<br/> Master Dummy Burst Counter<br/> In master mode, this field specifies the burst number that should be sent before receive in dual SPI mode.<br/> The data is don't care by the device.<br/> 0: 0 burst<br/> 1: 1 burst<br/> ...<br/> N: N bursts<br/> <b>Note: Can't be written when XCH=1.</b></p>                                         |
| 23:0           | R/W        | 0x0         | <p>STC<br/> Master Single Mode Transmit Counter<br/> In master mode, this field specifies the burst number that should be sent in single mode before automatically sending dummy burst. This is the first transmit counter in all bursts.<br/> 0: 0 burst<br/> 1: 1 burst<br/> ...<br/> N: N bursts<br/> <b>Note: Can't be written when XCH=1.</b></p> |

#### 8.15.6.12 0x0040 SPI Bit-Aligned Transfer Configure Register (Default Value: 0x0000\_00A0)

| Offset: 0x0040 |            |             | Register Name: SPI_BATCR                                                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                       |
| 31             | R/WAC      | 0x0         | <p>TCE<br/> Transfer Control Enable<br/> In master mode, it is used to start t1o transfer the</p> |

| Offset: 0x0040 |            |             | Register Name: SPI_BATCR                                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                              |
|                |            |             | <p>serial bit's frame, it is only valid when Work Mode Select==0x10/0x11.</p> <p>0: Idle<br/>1: Initiates transfer.<br/>Write "1" to this bit will start to transfer serial bits' frame (the value comes from the SPI TX Bit Register or SPI RX Bit Register), and will auto clear after the bursts transfer completely. Write '0' to this bit has no effect.</p>        |
| 30             | R/W        | 0x0         | <p>MSMS<br/>Master Sample Standard<br/>0: Standard Sample Mode<br/>1: Delay Sample Mode<br/>In Standard Sample Mode, SPI master samples the data at the standard rising edge of SCLK for each SPI mode;<br/>In Delay Sample Mode, SPI master samples data at the edge that is half cycle delayed by the standard rising edge of SCLK defined in respective SPI mode.</p> |
| 29:26          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                        |
| 25             | R/W1C      | 0x0         | <p>TBC<br/>Transfer Bits Completed<br/>When set, this bit indicates that the last bit of the serial data frame in SPI TX Bit Register (or SPI RX Bit Register) has been transferred completely. Writing 1 to this bit clears it.<br/>0: Busy<br/>1: Transfer Completed<br/><b>Note: It is only valid when Work Mode</b><br/><b>Select==0x10/0x11.</b></p>                |
| 24             | R/W        | 0x0         | <p>TBC_INT_EN<br/>Transfer Bits Completed Interrupt Enable<br/>0: Disable<br/>1: Enable<br/><b>Note: It is only valid when Work Mode</b><br/><b>Select==0x10/0x11.</b></p>                                                                                                                                                                                               |
| 23:22          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                        |
| 21:16          | R/W        | 0x00        | <p>RX_FEM_LEN<br/>Configure the length of serial data frame(burst) of RX<br/>000000: 0bit<br/>000001: 1bit</p>                                                                                                                                                                                                                                                           |

| Offset: 0x0040 |            |             | Register Name: SPI_BATCR                                                                                                                                                                                                                                                                                                                                                                                                         |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                |            |             | <p>...</p> <p>100000: 32bits</p> <p>Other values: reserved</p> <p><b>Note:</b> It is only valid when Work Mode<br/>Select==0x10/0x11, and can't be written when TCE=1.</p>                                                                                                                                                                                                                                                       |
| 15:14          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 13:8           | R/W        | 0x00        | <p>TX_FRM_LEN</p> <p>Configure the length of serial data frame(burst) of TX</p> <p>000000: 0bit</p> <p>000001: 1bit</p> <p>...</p> <p>100000: 32bits</p> <p>Other values: reserved</p> <p><b>Note:</b> It is only valid when Work Mode<br/>Select==0x10/0x11, and can't be written when TCE=1.</p>                                                                                                                               |
| 7              | R/W        | 0x1         | <p>SS_LEVEL</p> <p>When control SS signal manually, set this bit to '1' or '0' to control the level of SS signal.</p> <p>0: set SS to low</p> <p>1: set SS to high</p> <p><b>Note:</b> It is only valid when Work Mode<br/>Select==0x10/0x11, and only work in Mode0, can't be written when TCE=1.</p>                                                                                                                           |
| 6              | R/W        | 0x0         | <p>SS_OWNER</p> <p>SS Output Owner Select</p> <p>Usually, controller sends SS signal automatically with data together. When this bit is set to 1, software must manually write SPI_CTL_REG.SS_LEVEL to 1 or 0 to control the level of SS signal.</p> <p>0: SPI controller</p> <p>1: Software</p> <p><b>Note:</b> It is only valid when Work Mode<br/>Select==0x10/0x11, and only work in Mode0, can't be written when TCE=1.</p> |
| 5              | R/W        | 0x1         | <p>SPOL</p> <p>SPI Chip Select Signal Polarity Control</p> <p>0: Active high polarity (0 = Idle)</p> <p>1: Active low polarity (1 = Idle)</p> <p><b>Note:</b> It is only valid when Work Mode<br/>Select==0x10/0x11, and only work in Mode0, can't be written when TCE=1.</p>                                                                                                                                                    |

| Offset: 0x0040 |            |             | Register Name: SPI_BATCR                                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                               |
| 4              | /          | /           | /                                                                                                                                                                                                                                                                                                                                                         |
| 3:2            | R/W        | 0x0         | <p>SS_SEL<br/>SPI Chip Select<br/>Select one of four external SPI Master/Slave Devices<br/>00: SPI_SS0 will be asserted<br/>01: SPI_SS1 will be asserted<br/>10: SPI_SS2 will be asserted<br/>11: SPI_SS3 will be asserted</p> <p><b>Note:</b> It is only valid when Work Mode Select=0x10/0x11, and only work in Mode0, can't be written when TCE=1.</p> |
| 1:0            | R/W        | 0x0         | <p>WMS<br/><i>Work Mode Select</i><br/>00: Data frame is byte aligned in Standard SPI, Dual-Output/Dual Input SPI, Dual IO SPI and Quad-Output/Quad-Input SPI.<br/>01: Reserve<br/>10: Data frame is bit aligned in 3-Wire SPI<br/>11: Data frame is bit aligned in Standard SPI</p>                                                                      |

#### 8.15.6.13 0x0048 SPI TX Bit Register (Default Value: 0x0000\_0000)

| Offset: 0x0048 |            |             | Register Name: SPI_TBR                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                             |
| 31:0           | R/W        | 0x0         | <p>VTB<br/>The Value of the Transmit Bits<br/>This register is used to store the value of the transmitted serial data frame.</p> <p><b>Note:</b> In the process of transmission, the LSB is transmitted first.</p> <p>This register is only valid when Work Mode Select==0x10/0x11.</p> |

#### 8.15.6.14 0x004C SPI RX Bit Register (Default Value: 0x0000\_0000)

| Offset: 0x004C |            |             | Register Name: SPI_RBR                                                                                    |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                               |
| 31:0           | R/W        | 0x0         | <p>VRB<br/>The Value of the Receive Bits<br/>This register is used to store the value of the received</p> |

| Offset: 0x004C |            |             | Register Name: SPI_RBR                                                                                                                                                    |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                               |
|                |            |             | <p>serial data frame.</p> <p>Note: In the process of transmission, the LSB is transmitted first.</p> <p>This register is only valid when Work Mode Select==0x10/0x11.</p> |

#### 8.15.6.15 0x0088 SPI Normal DMA Mode Control Register (Default Value: 0x0000\_00E5)

| Offset: 0x0088 |            |             | Register Name: SPI_NDMA_MODE_CTL                                                                                                                                                                                 |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                      |
| 31:8           | /          | /           | /                                                                                                                                                                                                                |
| 7:6            | R/W        | 0x3         | <p>SPI_ACT_M</p> <p>SPI NDMA Active Mode</p> <p>00: DMA_active is low</p> <p>01: DMA_active is high</p> <p>10: DMA_active is controlled by dma_request(DRQ)</p> <p>11:DMA_active is controlled by controller</p> |
| 5              | R/W        | 0x1         | <p>SPI_ACK_M</p> <p>SPI NDMA Acknowledge Mode</p> <p>0: active fall do not care ACK</p> <p>1: active fall must after detect ACK is high</p>                                                                      |
| 4:0            | R/W        | 0x05        | <p>SPI_DMA_WAIT</p> <p>The counts of hold cycles from DMA last signal high to dma_active high</p>                                                                                                                |

#### 8.15.6.16 0x0200 SPI TX Data Register (Default Value: 0x0000\_0000)

| Offset: 0x0200 |            |             | Register Name: SPI_TXD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 31:0           | R/W        | 0x0         | <p>TDATA</p> <p>Transmit Data</p> <p>This register can be accessed in byte, half-word or word unit by AHB. In byte accessing method, if there are rooms in TXFIFO, one burst data is written to TXFIFO and the depth is increased by 1. In half-word accessing method, two SPI burst data are written and the TXFIFO depth is increase by 2. In word accessing method, four SPI burst data are written and the TXFIFO depth is increased by 4.</p> <p><b>Note: This address is writing-only if TF_TEST is '0',</b></p> |

| Offset: 0x0200 |            |             | Register Name: SPI_TXD                                                                                       |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                  |
|                |            |             | and if TF_TEST is set to '1', this address is readable and writable to test the TX FIFO through the AHB bus. |

#### 8.15.6.17 0x0300 SPI RX Data Register (Default Value: 0x0000\_0000)

| Offset: 0x0300 |            |             | Register Name: SPI_RXD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 31:0           | R          | 0x0         | <p>RDATa<br/>Receive Data</p> <p>This register can be accessed in byte, half-word or word unit by AHB. In byte accessing method, if there are data in RXFIFO, the top word is returned and the RXFIFO depth is decreased by 1. In half-word accessing method, two SPI bursts are returned and the RXFIFO depth is decrease by 2. In word accessing method, the four SPI bursts are returned and the RXFIFO depth is decreased by 4.</p> <p><b>Note:</b> This address is read-only if RF_TEST is '0', and if RF_TEST is set to '1', this address is readable and writable to test the RX FIFO through the AHB bus.</p> |

#### 8.15.6.18 0x0400 SPI BUF Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0400 |            |             | Register Name: SPI_BSR                                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                           |
| 31:19          | /          | /           | /                                                                                                                     |
| 18:16          | R          | 0x0         | <p>TB_CNT<br/>TX FIFO Write Buffer Counter</p> <p>These bits indicate the number of words in TX FIFO Write Buffer</p> |
| 15:8           | /          | /           | /                                                                                                                     |
| 7:0            | R          | 0x0         | <p>RB_CNT<br/>RX FIFO Read Buffer Counter</p> <p>These bits indicate the number of words in RX FIFO Read Buffer</p>   |

## 8.16 SPI\_DBI

### 8.16.1 Overview

The A523 provides a 3/4 line SPI display bus interface (SPI\_DBI) for video data transmission. It supports DBI mode or SPI mode. The DBI mode is compatible with multiple video data formats at the same time. The SPI mode is used for low-cost display schemes.

The SPI mode has the following features:

- Multiple SPI modes:
  - Master mode and slave mode for standard SPI
  - Master mode for Dual-Output/Dual-Input SPI and Dual I/O SPI
  - Master mode for Quad-Output/Quad-Input SPI
  - Master mode for 3-wire SPI, with programmable serial data frame length of 1 bit to 32 bits
- Maximum clock frequency: 100MHz
- TX/RX DMA slave interface
- 8-bit wide by 64-entry FIFO for both transmitting and receiving data
- Supports mode0, mode1, mode2, and mode3
- Polarity and phase of the Chip Select (SPI\_SS) and SPI Clock (SPI\_SCLK) are configurable

The DBI mode has the following features:

- DBI Type C 3 Line/4 Line Interface Mode
- 2 Data Lane Interface Mode
- RGB111/444/565/666/888 video format
- Maximum resolution of RGB666 240 x 320@30Hz with single data lane
- Maximum resolution of RGB888 240 x 320@60Hz or 320 x 480@30Hz with dual data lane
- Tearing effect
- Software flexible control video frame rate



#### NOTE

This chapter only describes SPI1 (SPI mode and DBI mode). For detailed information of SPI0, SPI2, and S\_SPI0, please refer to section 8.15 SPI.

## 8.16.2 Block Diagram

The following figure shows a block diagram of the SPI\_DBI.

**Figure 8-73 SPI\_DBI Block Diagram**



SPI\_DBI contains the following sub-blocks:

**Table 8-46 SPI\_DBI Sub-blocks**

| Sub-block      | Description                                                                                                                                                                       |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| spi_rf         | Responsible for implementing the internal register, interrupt, and DMA Request.                                                                                                   |
| spi_tbuf       | The data length transmitted from AHB to TXFIFO is converted into 8 bits, then the data is written into the RXFIFO.                                                                |
| spi_rbuf       | The block is used to convert the RXFIFO data into the reading data length of AHB.                                                                                                 |
| txfifo, rxfifo | The data transmitted from the SPI to the external serial device is written into the TXFIFO; the data received from the external serial device into SPI is pushed into the RXFIFO. |
| spi_cmu        | Responsible for implementing SPI bus clock, chip select, internal sample, and                                                                                                     |

| Sub-block | Description                                                                                                |
|-----------|------------------------------------------------------------------------------------------------------------|
|           | the generation of transfer clock.                                                                          |
| spi_tx    | Responsible for implementing SPI data transfer, the interface of the internal TXFIFO, and status register. |
| spi_rx    | Responsible for implementing SPI data receive, the interface of the internal RXFIFO, and status register.  |
| dbi_ctrl  | Responsible for implementing DBI bus clock, chip select, data command select, RGB format reshape.          |
| dbi_tx    | Responsible for implementing DBI data transfer, the interface of the internal TXFIFO, and status register. |
| dbi_rx    | Responsible for implementing DBI data receive, the interface of the internal RXFIFO, and status register.  |

### 8.16.3 Functional Description

#### 8.16.3.1 External Signals

The following table describes the external signals of SPI\_DBI. When using SPI\_DBI, the corresponding PADs are selected as SPI\_DBI function via section 8.5 GPIO.

**Table 8-47 GPIO multiplexing of SPI1 and DBI**

| DBI                      | SPI1      |
|--------------------------|-----------|
| DBI-CSX                  | SPI1-CS0  |
| DBI-SCLK                 | SPI1-CLK  |
| DBI-SDO                  | SPI1-MOSI |
| DBI-SDI/ DBI-TE/ DBI-DCX | SPI1-MISO |
| DBI-DCX/DBI-WRX          | SPI1-HOLD |
| DBI-TE                   | SPI1-WP   |

**Table 8-48 SPI\_DBI External Signals**

| Signal Name     | Description                                                                                                                                                                                           | Type |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| <b>SPI Mode</b> |                                                                                                                                                                                                       |      |
| SPI1-CS0        | SPI1 Chip Select Signal, Low Active                                                                                                                                                                   | I/O  |
| SPI1-CLK        | SPI1 Clock Signal<br>Provides serial interface timing.                                                                                                                                                | I/O  |
| SPI1-MOSI       | SPI1 Master Data Out, Slave Data In                                                                                                                                                                   | I/O  |
| SPI1-MISO       | SPI1 Master Data In, Slave Data Out                                                                                                                                                                   | I/O  |
| SPI1-WP         | SPI1 Write Protect, Low Active<br>Protects the memory area against all program or erase instructions.<br>It also can be used for serial data input and output for SPI Quad Input or Quad Output mode. | I/O  |
| SPI1-HOLD       | SPI1 Hold Signal                                                                                                                                                                                      | I/O  |

| Signal Name     | Description                                                                                                                                                                          | Type |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
|                 | Pauses any serial communication with the device without deselecting or resetting it.<br>It also can be used for serial data input and output for SPI Quad Input or Quad Output mode. |      |
| <b>DBI Mode</b> |                                                                                                                                                                                      |      |
| DBI-CSX         | Chip Select Signal, Low Active                                                                                                                                                       | I/O  |
| DBI-SCLK        | Serial Clock Signal                                                                                                                                                                  | I/O  |
| DBI-SDO         | Data Output Signal                                                                                                                                                                   | I/O  |
| DBI-SDI         | Data Input Signal<br>The data is sampled on the rising edge and the falling edge                                                                                                     | I/O  |
| DBI-TE          | Tearing Effect Input<br>It is used to capture the external TE signal edge. The rising and falling edge is configurable.                                                              | I/O  |
| DBI-DCX         | DCX pin is the select output signal of data and command.<br>DCX = 0: register command;<br>DCX = 1: data or parameter.                                                                | I/O  |
| DBI-WRX         | When DBI operates in dual data lane format, the RGB666 format 2 can use WRX to transfer data                                                                                         | I/O  |

### 8.16.3.2 Clock Sources

The SPI\_DBI controller gets 5 different clock sources, users can select one of them to make SPI\_DBI clock source. The following table describes the clock sources for SPI\_DBI. For more details on the clock setting, configuration, and gating information, see section 2.5 Clock Controller Unit (CCU).

Table 8-49 SPI\_DBI Clock Sources

| Clock Sources | Description                                 | Clock Module |
|---------------|---------------------------------------------|--------------|
| HOSC          | 24 MHz Crystal                              | CCU          |
| PERI0_200M    | Peripheral Clock, default value is 200 MHz. |              |
| PERI0_300M    | Peripheral Clock, default value is 300 MHz. |              |
| PERI1_200M    | Peripheral Clock, default value is 200 MHz. |              |
| PERI1_300M    | Peripheral Clock, default value is 300 MHz. |              |

### 8.16.3.3 Typical Application

The following figure shows the application block diagram when the SPI master device is connected to a slave device.

Figure 8-74 SPI Application Block Diagram



The following figure shows the application block diagram when the DBI master device is connected to a display bus interface device.

Figure 8-75 DBI Application Block Diagram



### 8.16.3.4 SPI Transmission Format

The SPI supports 4 different formats for data transmission. The software can select one of the four modes in which the SPI works by setting the bit1 (Polarity) and bit0 (Phase) of [SPI\\_TCR](#). The SPI controller master uses the SPI\_SCLK signal to transfer data in and out of the shift register. Data is clocked using any one of four programmable clock phase and polarity combinations.

The CPOL ([SPI\\_TCR\[1\]](#)) defines the polarity of the clock signal (SPI\_SCLK). The SPI\_SCLK is a high level when CPOL is '1' and it is a low level when CPOL is '0'. The CPHA ([SPI\\_TCR\[0\]](#)) decides whether the leading edge of SPI\_SCLK is used to setup or sample data. The leading edge is used to setup data when CPHA is '1', and sample data when CPHA is '0'. The following table lists the four modes.

**Table 8-50 SPI Transmit Format**

| SPI Mode | Polarity (CPOL) | Phase (CPHA) | Leading Edge               | Trailing Edge              |
|----------|-----------------|--------------|----------------------------|----------------------------|
| mode0    | 0               | 0            | Sample on the rising edge  | Setup on the falling edge  |
| mode1    | 0               | 1            | Setup on the rising edge   | Sample on the falling edge |
| mode2    | 1               | 0            | Sample on the falling edge | Setup on the rising edge   |
| mode3    | 1               | 1            | Setup on the falling edge  | Sample on the rising edge  |

The following figures describe four waveforms for SPI\_SCLK.

**Figure 8-76 SPI Phase 0 Timing Diagram****Figure 8-77 SPI Phase 1 Timing Diagram**

### 8.16.3.5 SPI Master and Slave Mode

The SPI controller can be configured to a master or slave device. The master mode is selected by setting the MODE bit ([SPI\\_GCR\[1\]](#)); the slave mode is selected by clearing the MODE bit.

In master mode, the SPI\_CLK is generated and transmitted to the external device, and the data from the TX FIFO is transmitted on the MOSI pin, the data from the slave is received on the MISO pin and sent to RX FIFO. The Chip Select (SPI\_SS) is an active low signal, and it must be set low

before the data are transmitted or received. The SPI\_SS can be selected the auto control mode or the software manual control mode. When using auto control, the SS\_OWNER ([SPI\\_TCR\[6\]](#)) must be cleared (default value is 0); when using manual control, the SS\_OWNER must be set. And the level of SPI\_SS is controlled by SS\_LEVEL ([SPI\\_TCR\[7\]](#)).

In slave mode, after the software selects the MODE bit ([SPI\\_GCR \[1\]](#)) to '0', it waits for master initiate a transaction. When the master asserts SPI\_SS, and SPI\_CLK is transmitted to the slave, the slave data is transmitted from TX FIFO on the MISO pin, and the data from the MOSI pin is received in RX FIFO.

#### 8.16.3.6 SPI 3-Wire Mode

The SPI 3-wire mode is only valid when the SPI controller work in master mode, and is selected when the Work Mode Select bit ([SPI\\_BATC \[1:0\]](#)) is equal to 0x2. And in the 3-wire mode, the input data and the output data use the same single data line. The following figure describes the 3-wire mode.

Figure 8-78 SPI 3-Wire Mode



### 8.16.3.7 SPI Dual-Input/Dual-Output and Dual I/O Mode

The dual read mode (SPI x2) is selected when the DRM is set in [SPI\\_BCC](#) [28]. Using the dual mode allows data to be transferred to or from the device at double the rate of standard single mode SPI devices, the data can be read at fast speed using two data bits (MOSI and MISO) at a time. The following figure describes the dual-input/dual-output SPI and the dual I/O SPI

**Figure 8-79 SPI Dual-Input/Dual-Output Mode**



In the dual-input/dual-output SPI mode, the command, address, and the dummy bytes output in a unit of a single bit in serial mode through the SPI\_MOSI line, only the data bytes are output (write) and input (read) in a unit of dual bits through the SPI\_MOSI and SPI\_MISO.

**Figure 8-80 SPI Dual I/O Mode**



In the dual I/O SPI mode, only the command bytes output in a unit of a single bit in serial mode through the SPI\_MOSI line. The address bytes and the dummy bytes output in a unit of dual bits through the SPI\_MOSI and SPI\_MISO. And the data bytes output (write) and input (read) in a unit of dual bits through the SPI\_MOSI and SPI\_MISO.

### 8.16.3.8 SPI Quad-Input/Quad-Output Mode

The quad read mode (SPI x4) is selected when the Quad\_EN is set in [SPI\\_BCC](#) [29]. Using the quad mode allows data to be transferred to or from the device at 4 times the rate of standard single mode SPI devices, the data can be read at fast speed using four data bits (MOSI, MISO, IO2 (WP#) and IO3 (HOLD#)) at the same time. The following figure describes the quad-input/quad-output SPI.

**Figure 8-81 SPI Quad-Input/Quad-Output Mode**



In the quad-input/quad-output SPI mode, the command, address, and the dummy bytes output in a unit of a single bit in serial mode through the SPI\_MOSI line. Only the data bytes output (write) and input (read) in a unit of quad bits through the SPI\_MOSI, SPI\_MISO, SPI\_WP#, and SPI\_HOLD#.

### 8.16.3.9 Transmission/Reception Bursts in Master Mode

In SPI master mode, the transmission and reception bursts (byte in unit) are configured before the SPI transfers serial data between the processor and external device. The transmission bursts are written in MWTC (bit [23:0]) of the [SPI Master Transmit Counter Register](#). The transmission bursts in single mode before automatically sending dummy bursts are written in STC (bit [23:0]) of the [SPI Master Burst Control Counter Register](#). For dummy data, the SPI controller can automatically send before receiving by writing DBC (bit [27:24]) in the [SPI Master Burst Control Counter Register](#). If users do not use the SPI controller to send dummy data automatically, then the dummy bursts are used as the transmission counters to write together in MWTC (bit [23:0]) of the [SPI Master Transmit Counter Register](#). In master mode, the total burst numbers are written in MBC (bit [23:0]) of the [SPI Master Burst Counter Register](#). When all transmission and reception bursts are transferred, the SPI controller will send a completed interrupt, at the same time, the SPI controller will clear DBC, MWTC, and MBC.

### 8.16.3.10 SPI Sample Mode and Run Clock Configuration

The SPI controller runs at 3 kHz–100 MHz at its interface to external SPI devices. The internal SPI clock should run at the same frequency as the outgoing clock in the master mode. The SPI clock is selected from different clock sources, the SPI must configure different work mode. There are three work modes: normal sample mode, delay half-cycle sample mode, delay one-cycle sample mode. Delay half-cycle sample mode is the default mode of the SPI controller. When the SPI runs at 40 MHz or below 40 MHz, the SPI can work at normal sample mode or delay half-cycle sample mode. When the SPI runs over 80 MHz, setting the SDC bit in the [SPI Transfer Control Register](#) to '1' makes the internal read sample point with a half-cycle delay of SPI\_CLK, which is used in high speed read operation to reduce the error caused by the time delay of SPI\_CLK between master and slave. The following tables show the different configurations of the SPI sample mode.

**Table 8-51 SPI Old Sample Mode and Run Clock**

| SPI Sample Mode         | SDM(bit13) | SDC(bit11) | Run Clock |
|-------------------------|------------|------------|-----------|
| normal sample           | 1          | 0          | <=24 MHz  |
| delay half cycle sample | 0          | 0          | <=40 MHz  |
| delay one cycle sample  | 0          | 1          | >=80 MHz  |



**CAUTION**

The remaining spectrum is not recommended. Because when the output delay of SPI flash (refer to the datasheet of the manufacturer for the specific delay time) is the same with the half-cycle time of SPI working clock, the variable edge of the output data for the device bumps into the clock sampling edge of the controller, so setting 1 cycle of sampling delay would cause stability problem.

**Table 8-52 SPI New Sample Mode**

| SPI Sample Mode         | SDM (bit13) | SDC (bit11) | SDC1 (bit15) |
|-------------------------|-------------|-------------|--------------|
| normal sample           | 1           | 0           | 0            |
| delay half cycle sample | 0           | 0           | 0            |
| delay one cycle sample  | 0           | 1           | 0            |
| delay 1.5 cycle sample  | 1           | 1           | 0            |
| delay 2 cycle sample    | 1           | 0           | 1            |
| delay 2.5 cycle sample  | 0           | 0           | 1            |
| delay 3 cycle sample    | 0           | 1           | 1            |

### 8.16.3.11 DBI 3-Line Interface Writing and Reading Timing

The 3-line DBI Interface I contains CSX, SDA, and SCL, where SDA shares this port for bidirectional port data input and output.

The 3-line DBI Interface II contains CSX, SDA, SCL, and SDI; Data input and output ports are independent of each other.

Since the 3-line display bus mode has no Data/Command data line indicating whether Data or Command is currently being transmitted, an extra bit is added to the data-stream before MSB to indicate whether Data or Command is currently being transmitted. (0: Command, 1: Data)

The following figure shows the writing operation format of 3-line DBI Interface I and Interface II.

**Figure 8-82 DBI 3-Line Display Bus Serial Interface Writing Operation Format**



The 3-line DBI Interface I uses the SDA port as bidirectional data input and output port. There are only three cases of data reading volume, 8bits/24bits/32bits, and the first data sampled is high.

The following figure shows the 8 bits reading operation format of 3-line DBI Interface I and Interface II. After the read command is transmitted, the data is read immediately with on dummy period.

**Figure 8-83 DBI 3-Line Display Bus Serial Interface 8-bit Reading Operation Format**



The following figure shows the 24 bits reading operation format of 3-line DBI Interface I and Interface II. After the read command is transmitted, the data is read after waiting for the dummy clock cycle.

**Figure 8-84 DBI 3-Line Display Bus Serial Interface 24-bit Reading Operation Format**



The following figure shows the 32 bits reading operation format of 3-line DBI Interface I and Interface II. After the read command is transmitted, the data is read after waiting for the dummy clock cycle.

**Figure 8-85 DBI 3-Line Display Bus Serial Interface 32-bit Reading Operation Format**



### 8.16.3.12 DBI 4-Line Interface Writing and Reading Timing

The 4-line DBI Interface I contains CSX, D/CX, SDA, and SCL, where SDA shares this port for bidirectional port data input and output.

The 4-line DBI Interface II contains CSX, D/CX, SDA, SCL, and SDI; Data input and output ports are independent of each other.

Since the 4-line display bus mode has a Data/Command data line indicating whether Data or Command is currently being transmitted (0: Command, 1: Data). So there is no need to add an extra bit to data-stream before MSB like the 3-line DBI.

The following figure shows the writing operation format of 4-line DBI Interface I and Interface II.

Figure 8-86 DBI 4-Line Display Bus Serial Interface Writing Operation Format



The following figure shows the 8 bits reading operation format of 4-line DBI Interface I and Interface II.

Figure 8-87 DBI 4-Line Display Bus Serial Interface 8-bit Reading Operation Format



The following figure shows the 24 bits reading operation format of 4-line DBI Interface I and Interface II.

Figure 8-88 DBI 4-Line Display Bus Serial Interface 24-bit Reading Operation Format



The following figure shows the 32 bits reading operation format of 4-line DBI Interface I and Interface II.

Figure 8-89 DBI 4-Line Display Bus Serial Interface 32-bit Reading Operation Format



### 8.16.3.13 DBI 3-Line Interface Transmit Video Format

Figure 8-90 RGB111 3-Line Interface Transmit Video Format



Figure 8-91 RGB444 3-Line Interface Transmit Video Format



Figure 8-92 RGB565 3-Line Interface Transmit Video Format



Figure 8-93 RGB666 3-Line Interface Transmit Video Format



### 8.16.3.14 DBI 4-Line Interface Transmit Video Format

Figure 8-94 RGB111 4-Line Interface Transmit Video Format



Figure 8-95 RGB444 4-Line Interface Transmit Video Format



Note 1. Pixel data with 12-bit color depth information

Note 2. The most significant bits are: Rx3, Gx3 and Bx3

Note 3. The least significant bits are: Rx0, Gx0 and Bx0

Figure 8-96 RGB565 4-Line Interface Transmit Video Format



Figure 8-97 RGB666 4-Line Interface Transmit Video Format



### 8.16.3.15 DBI 2 Data Lane Interface Transmit Video Format

For RGB444:

Figure 8-98 RGB444 2 Data Lane Interface Transmit Video Format



Figure 8-99 RGB565 2 Data Lane Interface Transmit Video Format



Figure 8-100 RGB666 2 Data Lane Interface Transmit Video Format 0



Figure 8-101 RGB666 2 Data Lane Interface Transmit Video Format 1 (ilitek)



Figure 8-102 RGB666 2 Data Lane Interface Transmit Video Format 2 (New vision)



Figure 8-103 RGB888 2 Data Lane Interface Transmit Video Format



Note 1. Pixel data with 24-bit color information

Note 2. The most significant bits are: R7, G7 and B7

Note 3. The least significant bits are: R0, G0 and B0

## 8.16.4 Programming Guidelines

### 8.16.4.1 Writing/Reading Data Process Using SPI Mode

The SPI transfers serial data between the processor and the external device. CPU and DMA are the two main operational modes for SPI. For each SPI, the data is simultaneously transmitted (shifted out serially) and received (shifted in serially). The SPI has 2 channels, including the TX

channel and RX channel. The TX channel has the path from TX FIFO to the external device. The RX channel has the path from the external device to RX FIFO.

**Write Data:** CPU or DMA must write data on the [SPI\\_TXD](#) register, the data on the register are automatically moved to TX FIFO.

**Read Data:** To read data from RX FIFO, CPU or DMA must access the register [SPI\\_RXD](#) and data are automatically sent to the register [SPI\\_RXD](#).

In CPU or DMA mode, the SPI sends a completed interrupt ([SPI\\_ISR\[TC\]](#)) to the processor at the end of each transfer.



## CPU Mode

Figure 8-104 SPI Write/Read Data in CPU Mode



## DMA Mode

Figure 8-105 SPI Write/Read Data in DMA Mode



#### 8.16.4.2 Transmitting Write Command Using DBI Mode

- Step 1** Set the SPI\_DBI\_MODE\_SEL (bit3) of [SPI\\_GCR](#) (0x0004) to 1 to select DBI mode.
- Step 2** Set the DBI EN MODE SEL (bit[30:29]) of [DBI\\_CTL\\_1](#) (0x0104) to 0 to select the trigger mode of DBI.
- Step 3** Configure the [DBI\\_CTL\\_0](#) (0x0100).
- Set [DBI\\_CTL\\_0](#)[Command Type] (bit31) to 0 to configure the writing command.
  - Set [DBI\\_CTL\\_0](#)[Write Command Dummy Cycles] (bit[30:20]) to configure the number of dummy cycles between commands.
  - Set [DBI\\_CTL\\_0](#)[Output Data Sequence] (bit19) to select the MSB or LSB.
  - Set [DBI\\_CTL\\_0](#)[Transmit Mode] (bit15) to 0 to select the command path.
  - Set [DBI\\_CTL\\_0](#)[Output Data Format] (bit[14:12]) to 0 to transmit the command.
  - Set [DBI\\_CTL\\_0](#)[DBI interface Select] (bit[10:8]) to select the DBI interface type.
  - The remaining values of the [DBI\\_CTL\\_0](#) register remain the default value.
- Step 4** Set [DBI\\_CTL\\_1](#)[DCX\_DATA] (bit22) to 0 to send the command.
- Step 5** DMA Path: Configure the [SPI\\_FCR](#) register (0x0018).
- Set [SPI\\_FCR](#)[TF\_DRQ\_EN] (bit24) to 1 to enable TXFIFO DMA.
  - Set [SPI\\_FCR](#)[TX\_TRIG\_LEVEL] (bit[23:16]) to 255. It indicates the controller requests data from DMA if the remaining space of TX FIFO is greater than 255.
- CPU Path: Write the command to be sent to the 0x200 address.
- Step 6** Set [SPI\\_GCR](#)[DBI\_EN] (bit4) to 1 to start transmitting the command.
- Step 7** Wait until the TX FIFO underrun interrupt ([SPI\\_ISR](#)[TF\_UDF]) is 1. It indicates that the command written to the TX FIFO is transmitted completely.

#### 8.16.4.3 Transmitting Parameter Using DBI Mode

- Step 1** Set the SPI\_DBI\_MODE\_SEL (bit3) of [SPI\\_GCR](#) (0x0004) to 1 to select DBI mode.
- Step 2** Set the DBI EN MODE SEL (bit[30:29]) of [DBI\\_CTL\\_1](#) (0x0104) to 0 to select the trigger mode of DBI.
- Step 3** Configure the [DBI\\_CTL\\_0](#) register (0x0100).
- Set [DBI\\_CTL\\_0](#)[Command Type] (bit31) to 0 to configure the writing command.
  - Set [DBI\\_CTL\\_0](#)[Write Command Dummy Cycles] (bit[30:20]) to configure the number of dummy cycles between commands.
  - Set [DBI\\_CTL\\_0](#)[Output Data Sequence] (bit19) to select the MSB or LSB.

- d) Set [DBI\\_CTL\\_0](#)[Transmit Mode] (bit15) to 0 to select the command path.
- e) Set [DBI\\_CTL\\_0](#)[Output Data Format] (bit[14:12]) to 0 to transmit the command.
- f) Set [DBI\\_CTL\\_0](#)[DBI interface Select] (bit[10:8]) to select the DBI interface type.
- g) The remaining values of the [DBI\\_CTL\\_0](#) register remain the default value.

**Step 4** Set [DBI\\_CTL\\_1](#)[DCX\_DATA] (bit22) to 1 to send the parameter.

**Step 5** DMA Path: Configure the [SPI\\_FCR](#) register (0x0018).

- a) Set [SPI\\_FCR](#)[TF\_DRQ\_EN] (bit24) to 1 to enable TXFIFO DMA.
- b) Set [SPI\\_FCR](#)[TX\_TRIG\_LEVEL] (bit[23:16]) to 255. It indicates the controller requests data from DMA if the remaining space of TX FIFO is greater than 255.

CPU Path: Write the command to be sent to the 0x200 address.

**Step 6** Set [SPI\\_GCR](#)[DBI\_EN] (bit4) to 1 to start transmitting the command.

**Step 7** Wait until the TX FIFO underrun interrupt ([SPI\\_ISR](#)[TF\_UDF]) is 1. It indicates that the command written to the TX FIFO is transmitted completely.

#### 8.16.4.4 Transmitting Video Using DBI Mode

Set the SPI\_DBI\_MODE\_SEL (bit3) of [SPI\\_GCR](#) (0x0004) to 1 to select DBI mode.

If the data is from the CPU path, the controller writes the command to be sent to the 0x0200 address by the AHB bus.

If the data is from the DMA path, configure [DBI\\_CTL\\_1](#)[DBI\_FIFO\_DRQ\_EN] (bit15) to 1 and [DBI\\_CTL\\_1](#)[TX\_TRIG\_LEVEL] (bit[14:8]) to 64, which indicates the controller requests data from DMA if the remaining space of TX FIFO is greater than 64.

##### Software Trigger Mode

The software enables DBI\_en\_trigger when the edge interrupt of TE is detected.

After transmitting each frame image, the controller clears automatically the line\_cnt, pixel\_cnt and stops transmitting data.

Wait for the edge interrupt of TE, the software needs to enable DBI\_en\_trigger, in circulation.

The operation process is as follows.

**Step 1** Set the SPI\_DBI\_MODE\_SEL (bit3) of [SPI\\_GCR](#) (0x0004) to 1 to select DBI mode.

**Step 2** Set the DBI EN MODE SEL (bit[30:29]) of [DBI\\_CTL\\_1](#) (0x0104) to 1 to select the software trigger mode.

**Step 3** Configure the [DBI\\_CTL\\_0](#) register (0x0100).

- a) Set [DBI\\_CTL\\_0](#)[Command Type] (bit31) to 0 to set the writing command.

- b) Set [DBI\\_CTL\\_0](#)[Write Command Dummy Cycles] (bit[30:20]) to configure the number of dummy cycles between commands.
- c) Set [DBI\\_CTL\\_0](#)[Output Data Sequence] (bit19) to select the MSB or LSB.
- d) Set [DBI\\_CTL\\_0](#)[Transmit Mode] (bit15) to 1 to select the image path.
- e) Set [DBI\\_CTL\\_0](#)[Output Data Format] (bit[14:12]) to select RGB111//444/565/666/888.
- f) Set [DBI\\_CTL\\_0](#)[DBI interface Select] (bit[10:8]) to select the DBI interface type.
- g) The remaining values of the [DBI\\_CTL\\_0](#) register remain the default value.

**Step 4** Set [DBI\\_CTL\\_1](#)[DCX\_DATA] (bit22) to 0 to send the image data.

**Step 5** Configure [DBI\\_Video\\_Size](#) (0x110) according to the sent image size.

**Step 6** Configure [DBI\\_CTL\\_2](#) (0x0108) to set the TE-related parameter.

**Step 7** Detect the TE interrupt of the [DBI\\_INT](#) (0x0120) register.

**Step 8** Configure [DBI\\_CTL\\_1](#)[DBI\_soft\_trigger] to 1.

### Timer Trigger Mode

The software configures timer\_en to enable timer counting, and when the counter reaches the specified value, the DBI\_EN automatically can be enabled to start transmitting data.

After transmitting each frame image, the controller clears automatically the line\_cnt, pixel\_cnt, and stops transmitting data.

The timer starts counting again. When the counter reaches the specified value, the controller automatically enables DBI\_EN, and in circulation until the software turns off the timer\_en.

The operation process is as follows.

**Step 1** Set the SPI\_DBI\_MODE\_SEL (bit3) of [SPI\\_GCR](#) (0x0004) to 1 to select DBI mode.

**Step 2** Set the DBI EN MODE SEL (bit30:29) of [DBI\\_CTL\\_1](#) (0x0104) to 2 to select the timer trigger mode.

**Step 3** Configure the [DBI\\_CTL\\_0](#) register (0x0100).

- a) Set [DBI\\_CTL\\_0](#)[Command Type] (bit31) to 0 to set the writing command.
- b) Set [DBI\\_CTL\\_0](#)[Write Command Dummy Cycles] (bit[30:20]) to configure the number of dummy cycles between commands.
- c) Set [DBI\\_CTL\\_0](#)[Output Data Sequence] (bit19) to select the MSB or LSB.
- d) Set [DBI\\_CTL\\_0](#)[Transmit Mode] (bit15) to 1 to select the image path.
- e) Set [DBI\\_CTL\\_0](#)[Output Data Format] (bit[14:12]) to select RGB111/444/565/666/888.
- f) Set [DBI\\_CTL\\_0](#)[DBI interface Select] (bit[10:8]) to select the DBI interface type.
- g) The remaining values of the [DBI\\_CTL\\_0](#) register remain the default value.

**Step 4** Set [DBI\\_CTL\\_1\[DCX\\_DATA\]](#) (bit22) to 0 to send the image data.

**Step 5** Configure [DBI\\_Video\\_Size](#) (0x110) to transmit the image size.

**Step 6** Configure the related parameter of DBI\_Timer (0x10C).

### TE Trigger Mode

When the edge changes of the TE are detected (The rising and falling edges are optional), the DBI\_EN automatically can be enabled to start transmitting data.

After transmitting each frame image, the controller clears automatically the line\_cnt, pixel\_cnt, and stops transmitting data.

When the edge changes of the TE are detected (The rising and falling edges are optional), the DBI\_EN automatically can be enabled to start transmitting data until the software shuts down TE\_EN or the screen no longer sends TE signals.

The operation process is as follows.

**Step 1** Set the SPI\_DBI\_MODE\_SEL (bit3) of [SPI\\_GCR](#) (0x0004) to 1 to select DBI mode.

**Step 2** Set the DBI EN MODE SEL (bit30:29) of [DBI\\_CTL\\_1](#) (0x0104) to 3 to select the TE  
Configure the [DBI\\_CTL\\_0](#) register (0x0100).

**Step 3** Set [DBI\\_CTL\\_0\[Command Type\]](#) (bit31) to 0 to set the writing command.

- a) Set [DBI\\_CTL\\_0\[Write Command Dummy Cycles\]](#) (bit[30:20]) to configure the number of dummy cycles between commands.
- b) Set [DBI\\_CTL\\_0\[Output Data Sequence\]](#) (bit19) to select the MSB or LSB.
- c) Set [DBI\\_CTL\\_0\[Transmit Mode\]](#) (bit15) to 1 to select the image path.
- d) Set [DBI\\_CTL\\_0\[Output Data Format\]](#) (bit[14:12]) to select RGB111/444/565/666/888.
- e) Set [DBI\\_CTL\\_0\[DBI interface Select\]](#) (bit[10:8]) to select the DBI interface type.
- f) The remaining values of the [DBI\\_CTL\\_0](#) register remain the default value.

**Step 4** Configure [DBI\\_CTL\\_1\[DCX\\_DATA\]](#) (bit22) to 0 to send the image data.

**Step 5** Configure [DBI\\_Video\\_Size](#) (0x0110) to transmit the image size.

**Step 6** Configure [DBI\\_CTL\\_2](#) (0x0108) to set the TE-related parameter.

#### 8.16.4.5 Transmitting Read Command and Read Data Using DBI Mode

**Step 1** Set the SPI\_DBI\_MODE\_SEL (bit3) of [SPI\\_GCR](#) (0x0004) to 1 to select DBI mode.

**Step 2** Set the DBI EN MODE SEL (bit[30:29]) of [DBI\\_CTL\\_1](#) (0x0104) to 0.

**Step 3** Configure the [DBI\\_CTL\\_0](#) register (0x0100).

- a) Set [DBI\\_CTL\\_0\[Command Type\]](#) (bit31) to 0 to set the reading command.

- b) Set [DBI\\_CTL\\_0](#)[Output Data Sequence] (bit19) to select the MSB or LSB.
- c) Set [DBI\\_CTL\\_0](#)[Transmit Mode] (bit15) to 0 to select the command path.
- d) Set [DBI\\_CTL\\_0](#)[Output Data Format] (bit[14:12]) to 0.
- e) Set [DBI\\_CTL\\_0](#)[DBI interface Select] (bit[10:8]) to select the DBI interface type.
- f) The remaining values of the [DBI\\_CTL\\_0](#) register remain the default value.

**Step 4** Configure the [DBI\\_CTL\\_1](#) register (0x0104).

- a) Configure [DBI\\_CTL\\_1](#)[DCX\_DATA] (bit22) to 0 to send the command.
- b) Configure [DBI\\_CTL\\_1](#)[Read\_MSB\_First] (bit20) to select whether the first bit of the read data is the highest or lowest bit of data.
- c) Configure [DBI\\_CTL\\_1](#)[Read Data Number of Bytes] to set the byte number to be read.
- d) Configure [DBI\\_CTL\\_1](#)[Read Command Dummy Cycles] to set the dummy cycle between the read command and the read data, when the dummy cycle is complete, the data starts to be sampled.

**Step 5** DMA Path: Configure the [SPI\\_FCR](#) register (0x0018).

- a) Set [SPI\\_FCR](#)[RF\_DRQ\_EN] (bit8) to 1 to enable RXFIFO DMA.
- b) Set [SPI\\_FCR](#)[RX\_TRIG\_LEVEL] (bit[7:0]) to 32, which indicates the controller requests receiving data from DMA if the data of the RX FIFO is greater than 64.

CPU Path: Read data in RX FIFO from the 0x0300 address.

**Step 6** Set [SPI\\_GCR](#)[DBI\_EN] (bit4) to 1 to start transmitting command.

**Step 7** Wait until [DBI\\_INT](#)[RD\_DONE\_INT] is 1. It indicates that the data is read completely.

### 8.16.5 Register List

| Module Name | Base Address |
|-------------|--------------|
| SPI1        | 0x0402 6000  |

| Register Name | Offset | Description                       |
|---------------|--------|-----------------------------------|
| SPI_GCR       | 0x0004 | SPI Global Control Register       |
| SPI_TCR       | 0x0008 | SPI Transfer Control register     |
| SPI_IER       | 0x0010 | SPI Interrupt Control register    |
| SPI_ISR       | 0x0014 | SPI Interrupt Status register     |
| SPI_FCR       | 0x0018 | SPI FIFO Control register         |
| SPI_FSR       | 0x001C | SPI FIFO Status register          |
| SPI_WCR       | 0x0020 | SPI Wait Clock Counter register   |
| SPI_SAMP_DL   | 0x0028 | SPI Sample Delay Control Register |
| SPI_MBC       | 0x0030 | SPI Master Burst Counter register |

| Register Name     | Offset | Description                                 |
|-------------------|--------|---------------------------------------------|
| SPI_MTC           | 0x0034 | SPI Master Transmit Counter Register        |
| SPI_BCC           | 0x0038 | SPI Master Burst Control Counter register   |
| SPI_BATCR         | 0x0040 | SPI Bit-Aligned Transfer Configure Register |
| SPI_TBR           | 0x0048 | SPI TX Bit Register                         |
| SPI_RBR           | 0x004C | SPI RX Bit Register                         |
| SPI_NDMA_MODE_CTL | 0x0088 | SPI Normal DMA Mode Control Register        |
| DBI_CTL_0         | 0x0100 | DBI Control Register 0                      |
| DBI_CTL_1         | 0x0104 | DBI Control Register 1                      |
| DBI_CTL_2         | 0x0108 | DBI Control Register 2                      |
| DBI_TIMER         | 0x010C | DBI Timer Control Register                  |
| DBI_VIDEO_SIZE    | 0x0110 | DBI Video Size Register                     |
| DBI_INT           | 0x0120 | DBI Interrupt Register                      |
| DBI_DEBUG_0       | 0x0124 | DBI DEBUG Register 0                        |
| DBI_DEBUG_1       | 0x0128 | DBI DEBUG Register 1                        |
| SPI_TXD           | 0x0200 | SPI TX Data register                        |
| SPI_RXD           | 0x0300 | SPI RX Data register                        |
| SPI_BSR           | 0x0400 | SPI BUF Status register                     |

## 8.16.6 Register Description

### 8.16.6.1 0x0004 SPI Global Control Register (Default Value: 0x0000\_0080)

| Offset: 0x0004 |            |             | Register Name: SPI_GCR                                                                                                                                                                                                                                                                        |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                   |
| 31             | R/WAC      | 0x0s        | SRST<br>Soft reset<br>Write '1' to this bit will clear the SPI controller, and auto clear to '0' when reset operation completes<br>Write '0' has no effect.                                                                                                                                   |
| 30:8           | /          | /           | /                                                                                                                                                                                                                                                                                             |
| 7              | R/W        | 0x1         | TP_EN<br>Transmit Pause Enable<br>In master mode, it is used to control transmit state machine to stop smart burst sending when RX FIFO is full.<br>1: Stop transmitting data when RXFIFO is full.<br>0: Normal operation, ignore RXFIFO status.<br><b>Note: Can't be written when XCH=1.</b> |
| 6:5            | /          | /           | /                                                                                                                                                                                                                                                                                             |
| 4              | R/W        | 0x0         | DBI_EN<br>DBI Module Enable Control                                                                                                                                                                                                                                                           |

| Offset: 0x0004 |            |             | Register Name: SPI_GCR                                                                                                                                         |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                    |
|                |            |             | 0: Disable<br>1: Enable                                                                                                                                        |
| 3              | R/W        | 0x0         | SPI_DBI_MODE_SEL<br>SDBISPI_DBI Working Mode Select<br>0: SPI MODE<br>1: DBI MODE                                                                              |
| 2              | R/W        | 0x0         | MODE_SELEC<br>Sample Timing Mode Select<br>0: Old mode of Sample Timing<br>1: New mode of Sample Timing<br><b>Note: Can't be written when XCH=1.</b>           |
| 1              | R/W        | 0x0         | MODE<br>SPI Function Mode Select<br>0: Slave Mode<br>1: Master Mode<br><b>Note: Can't be written when XCH=1.</b>                                               |
| 0              | R/W        | 0x0         | EN<br>SPI Module Enable Control<br>0: Disable<br>1: Enable<br><b>Note: After transforming from bit_mode to byte_mode, it must Enable the SPI Module again.</b> |

#### 8.16.6.2 0x0008 SPI Transfer Control Register (Default Value: 0x0000\_0087)

| Offset: 0x0008 |            |             | Register Name: SPI_TCR                                                                                                                                                                                                                                                                                                                                               |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                          |
| 31             | R/WAC      | 0x0         | XCH<br>Exchange Burst<br>In master mode it is used to start SPI burst<br>0: Idle<br>1: Initiates exchange.<br>Write "1" to this bit will start the SPI burst, and will auto clear after finishing the bursts transfer specified by BC. Write "1" to SRST will also clear this bit. Write '0' to this bit has no effect.<br><b>Note: Can't be written when XCH=1.</b> |
| 30:16          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                    |
| 15             | R/W        | 0x0         | SDC1<br>Master Sample Data Control register1<br>Set this bit to '1' to make the internal read sample                                                                                                                                                                                                                                                                 |

| Offset: 0x0008 |            |             | Register Name: SPI_TCR                                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                |            |             | <p>point with a delay of half cycle of SPI_CLK. It is used in high speed read operation to reduce the error caused by the time delay of SPI_CLK propagating between master and slave.</p> <p>0: normal operation, do not delay internal read sample point</p> <p>1: delay internal read sample point</p> <p><b>Note: Can't be written when XCH=1.</b></p>                                                                                             |
| 14             | R/W        | 0x0         | <p>SDDM<br/>Sending Data Delay Mode<br/>0: normal sending<br/>1: delay sending<br/>Set the bit to "1" to make the data that should be sent with a delay of half cycle of SPI_CLK in dual io mode for SPI mode 0.</p>                                                                                                                                                                                                                                  |
| 13             | R/W        | 0x0         | <p>SDM<br/>Master Sample Data Mode<br/>1: Normal Sample Mode<br/>0: Delay Sample Mode<br/>In Normal Sample Mode, SPI master samples the data at the correct edge for each SPI mode;<br/>In Delay Sample Mode, SPI master samples data at the edge that is half cycle delayed by the correct edge defined in respective SPI mode.</p>                                                                                                                  |
| 12             | R/W        | 0x0         | <p>FBS<br/>First Transmit Bit Select<br/>0: MSB first<br/>1: LSB first</p> <p><b>Note: Can't be written when XCH=1.</b></p>                                                                                                                                                                                                                                                                                                                           |
| 11             | R/W        | 0x0         | <p>SDC<br/>Master Sample Data Control<br/>Set this bit to '1' to make the internal read sample point with a delay of half cycle of SPI_CLK. It is used in high speed read operation to reduce the error caused by the time delay of SPI_CLK propagating between master and slave.</p> <p>0: normal operation, do not delay internal read sample point</p> <p>1: delay internal read sample point</p> <p><b>Note: Can't be written when XCH=1.</b></p> |
| 10             | R/W        | 0x0         | RPSM                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

| Offset: 0x0008 |            |             | Register Name: SPI_TCR                                                                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                         |
|                |            |             | <p>Rapids mode select<br/>Select Rapids mode for high speed write.<br/>0: normal write mode<br/>1: rapids write mode<br/><b>Note: Can't be written when XCH=1.</b></p>                                                                                                                                                              |
| 9              | R/W        | 0x0         | <p>DDB<br/>Dummy Burst Type<br/>0: The bit value of dummy SPI burst is zero<br/>1: The bit value of dummy SPI burst is one<br/><b>Note: Can't be written when XCH=1.</b></p>                                                                                                                                                        |
| 8              | R/W        | 0x0         | <p>DHB<br/>Discard Hash Burst<br/>In master mode it controls whether discarding unused SPI bursts<br/>0: Receiving all SPI bursts in BC period<br/>1: Discard unused SPI bursts, only fetching the SPI bursts during dummy burst period. The bursts number is specified by TC.<br/><b>Note: Can't be written when XCH=1.</b></p>    |
| 7              | R/W        | 0x1         | <p>SS_LEVEL<br/>When control SS signal manually (SPI_CTRL_REG.SS_CTRL==1), set this bit to '1' or '0' to control the level of SS signal.<br/>0: set SS to low<br/>1: set SS to high<br/><b>Note: Can't be written when XCH=1.</b></p>                                                                                               |
| 6              | R/W        | 0x0         | <p>SS_OWNER<br/>SS Output Owner Select<br/>Usually, controller sends SS signal automatically with data together. When this bit is set to 1, software must manually write SPI_CTRL_REG.SS_LEVEL to 1 or 0 to control the level of SS signal.<br/>0: SPI controller<br/>1: Software<br/><b>Note: Can't be written when XCH=1.</b></p> |
| 5:4            | R/W        | 0x0         | <p>SS_SEL<br/>SPI Chip Select<br/>Select one of four external SPI Master/Slave Devices<br/>00: SPI_SS0 will be asserted<br/>01: SPI_SS1 will be asserted<br/>10: SPI_SS2 will be asserted</p>                                                                                                                                       |

| Offset: 0x0008 |            |             | Register Name: SPI_TCR                                                                                                                                                                                                                                      |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                 |
|                |            |             | 11: SPI_SS3 will be asserted<br><b>Note: Can't be written when XCH=1.</b>                                                                                                                                                                                   |
| 3              | R/W        | 0x0         | SSCTL<br>In master mode, this bit selects the output wave form for the SPI_SSx signal. Only valid when SS_OWNER = 0.<br>0: SPI_SSx remains asserted between SPI bursts<br>1: Negate SPI_SSx between SPI bursts<br><b>Note: Can't be written when XCH=1.</b> |
| 2              | R/W        | 0x1         | SPOL<br>SPI Chip Select Signal Polarity Control<br>0: Active high polarity (0 = Idle)<br>1: Active low polarity (1 = Idle)<br><b>Note: Can't be written when XCH=1.</b>                                                                                     |
| 1              | R/W        | 0x1         | CPOL<br>SPI Clock Polarity Control<br>0: Active high polarity (0 = Idle)<br>1: Active low polarity (1 = Idle)<br><b>Note: Can't be written when XCH=1.</b>                                                                                                  |
| 0              | R/W        | 0x1         | CPHA<br>SPI Clock/Data Phase Control<br>0: Phase 0 (Leading edge for sample data)<br>1: Phase 1 (Leading edge for setup data)<br><b>Note: Can't be written when XCH=1.</b>                                                                                  |

#### 8.16.6.3 0x0010 SPI Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0010 |            |             | Register Name: SPI_IER                                                                                                     |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                |
| 31:14          | /          | /           | /                                                                                                                          |
| 13             | R/W        | 0x0         | SS_INT_EN<br>SSI Interrupt Enable<br>Chip Select Signal (SSx) from valid state to invalid state<br>0: Disable<br>1: Enable |
| 12             | R/W        | 0x0         | TC_INT_EN<br>Transfer Completed Interrupt Enable<br>0: Disable<br>1: Enable                                                |
| 11             | R/W        | 0x0         | TF_UDR_INT_EN                                                                                                              |

| Offset: 0x0010 |            |             | Register Name: SPI_IER                                                             |
|----------------|------------|-------------|------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                        |
|                |            |             | TXFIFO under run Interrupt Enable<br>0: Disable<br>1: Enable                       |
| 10             | R/W        | 0x0         | TF_OVF_INT_EN<br>TX FIFO Overflow Interrupt Enable<br>0: Disable<br>1: Enable      |
| 9              | R/W        | 0x0         | RF_UDR_INT_EN<br>RXFIFO under run Interrupt Enable<br>0: Disable<br>1: Enable      |
| 8              | R/W        | 0x0         | RF_OVF_INT_EN<br>RX FIFO Overflow Interrupt Enable<br>0: Disable<br>1: Enable      |
| 7              | /          | /           | /                                                                                  |
| 6              | R/W        | 0x0         | TF_FUL_INT_EN<br>TX FIFO Full Interrupt Enable<br>0: Disable<br>1: Enable          |
| 5              | R/W        | 0x0         | TX_EMP_INT_EN<br>TX FIFO Empty Interrupt Enable<br>0: Disable<br>1: Enable         |
| 4              | R/W        | 0x0         | TX_ERQ_INT_EN<br>TX FIFO Empty Request Interrupt Enable<br>0: Disable<br>1: Enable |
| 3              | /          | /           | /                                                                                  |
| 2              | R/W        | 0x0         | RF_FUL_INT_EN<br>RX FIFO Full Interrupt Enable<br>0: Disable<br>1: Enable          |
| 1              | R/W        | 0x0         | RX_EMP_INT_EN<br>RX FIFO Empty Interrupt Enable<br>0: Disable<br>1: Enable         |
| 0              | R/W        | 0x0         | RF_RDY_INT_EN<br>RX FIFO Ready Request Interrupt Enable<br>0: Disable<br>1: Enable |

## 8.16.6.4 0x0014 SPI Interrupt Status Register (Default Value: 0x0000\_0032)

| Offset: 0x0014 |            |             | Register Name: SPI_ISR                                                                                                                                                                                                                                                                                                                                     |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                |
| 31:14          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                          |
| 13             | R/W1C      | 0x0         | SSI<br>SS Invalid Interrupt<br>When SSI is 1, it indicates that SS has changed from valid state to invalid state. Writing 1 to this bit clears it.                                                                                                                                                                                                         |
| 12             | R/W1C      | 0x0         | TC<br>Transfer Completed<br>In master mode, it indicates that all bursts specified by BC has been exchanged. In other condition, When set, this bit indicates that all the data in TXFIFO has been loaded in the Shift register, and the Shift register has shifted out all the bits. Writing 1 to this bit clears it.<br>0: Busy<br>1: Transfer Completed |
| 11             | R/W1C      | 0x0         | TF_UDF<br>TXFIFO under run<br>This bit is set when if the TXFIFO is underrun. Writing 1 to this bit clears it.<br>0: TXFIFO is not underrun<br>1: TXFIFO is underrun                                                                                                                                                                                       |
| 10             | R/W1C      | 0x0         | TF_OVF<br>TXFIFO Overflow<br>This bit is set when if the TXFIFO is overflow. Writing 1 to this bit clears it.<br>0: TXFIFO is not overflow<br>1: TXFIFO is overflowed                                                                                                                                                                                      |
| 9              | R/W1C      | 0x0         | RX_UDF<br>RXFIFO Underrun<br>When set, this bit indicates that RXFIFO has underrun. Writing 1 to this bit clears it.                                                                                                                                                                                                                                       |
| 8              | R/W1C      | 0x0         | RX_OVF<br>RXFIFO Overflow<br>When set, this bit indicates that RXFIFO has overflowed. Writing 1 to this bit clears it.<br>0: RXFIFO is available.<br>1: RXFIFO has overflowed.                                                                                                                                                                             |
| 7              | /          | /           | /                                                                                                                                                                                                                                                                                                                                                          |

| Offset: 0x0014 |            |             | Register Name: SPI_ISR                                                                                                                                                                                                                   |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                              |
| 6              | R/W1C      | 0x0         | <p>TX_FULL<br/>TXFIFO Full<br/>This bit is set when if the TXFIFO is full . Writing 1 to this bit clears it.<br/>0: TXFIFO is not Full<br/>1: TXFIFO is Full</p>                                                                         |
| 5              | R/W1C      | 0x1         | <p>TX_EMP<br/>TXFIFO Empty<br/>This bit is set if the TXFIFO is empty. Writing 1 to this bit clears it.<br/>0: TXFIFO contains one or more words.<br/>1: TXFIFO is empty</p>                                                             |
| 4              | R/W1C      | 0x1         | <p>TX_READY<br/>TXFIFO Ready<br/>0: TX_WL &gt; TX_TRIG_LEVEL<br/>1: TX_WL &lt;= TX_TRIG_LEVEL<br/>This bit is set any time if TX_WL &lt;= TX_TRIG_LEVEL. Writing "1" to this bit clears it. Where TX_WL is the water level of RXFIFO</p> |
| 3              | /          | /           | /                                                                                                                                                                                                                                        |
| 2              | R/W1C      | 0x0         | <p>RX_FULL<br/>RXFIFO Full<br/>This bit is set when the RXFIFO is full . Writing 1 to this bit clears it.<br/>0: Not Full<br/>1: Full</p>                                                                                                |
| 1              | R/W1C      | 0x1         | <p>RX_EMP<br/>RXFIFO Empty<br/>This bit is set when the RXFIFO is empty . Writing 1 to this bit clears it.<br/>0: Not empty<br/>1: empty</p>                                                                                             |
| 0              | R/W1C      | 0x0         | <p>RX_RDY<br/>RXFIFO Ready<br/>0: RX_WL &lt;= RX_TRIG_LEVEL<br/>1: RX_WL &gt; RX_TRIG_LEVEL<br/>This bit is set any time if RX_WL &gt; RX_TRIG_LEVEL. Writing "1" to this bit clears it. Where RX_WL is the water level of RXFIFO.</p>   |

## 8.16.6.5 0x0018 SPI FIFO Control Register (Default Value: 0x0040\_0001)

| Offset: 0x0018 |            |             | Register Name: SPI_FCR                                                                                                                                                                                                                                                                                                                        |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                   |
| 31             | R/WAC      | 0x0         | <p>TX_FIFO_RST<br/>TX FIFO Reset<br/>Write '1' to this bit will reset the control portion of the TX FIFO and auto clear to '0' when completing reset operation, write to '0' has no effect.</p>                                                                                                                                               |
| 30             | R/W        | 0x0         | <p>TF_TEST_ENB<br/>TX Test Mode Enable<br/>0: disable<br/>1: enable<br/>In normal mode, TX FIFO can only be read by SPI controller, write '1' to this bit will switch TX FIFO read and write function to AHB bus. This bit is used to test the TX FIFO, don't set in normal operation and don't set RF_TEST and TF_TEST at the same time.</p> |
| 29:25          | /          | /           | /                                                                                                                                                                                                                                                                                                                                             |
| 24             | R/W        | 0x0         | <p>TF_DRQ_EN<br/>TX FIFO DMA Request Enable<br/>0: Disable<br/>1: Enable</p>                                                                                                                                                                                                                                                                  |
| 23:16          | R/W        | 0x40        | <p>TX_TRIG_LEVEL<br/>TX FIFO Empty Request Trigger Level</p>                                                                                                                                                                                                                                                                                  |
| 15             | R/WAC      | 0x0         | <p>RF_RST<br/>RXFIFO Reset<br/>Write '1' to this bit will reset the control portion of the receiver FIFO, and auto clear to '0' when completing reset operation, write '0' to this bit has no effect.</p>                                                                                                                                     |
| 14             | R/W        | 0x0         | <p>RF_TEST<br/>RX Test Mode Enable<br/>0: Disable<br/>1: Enable<br/>In normal mode, RX FIFO can only be written by SPI controller, write '1' to this bit will switch RX FIFO read and write function to AHB bus. This bit is used to test the RX FIFO, don't set in normal operation and don't set RF_TEST and TF_TEST at the same time.</p>  |
| 13:9           | /          | /           | /                                                                                                                                                                                                                                                                                                                                             |
| 8              | R/W        | 0x0         | <p>RF_DRQ_EN<br/>RX FIFO DMA Request Enable<br/>0: Disable</p>                                                                                                                                                                                                                                                                                |

| Offset: 0x0018 |            |             | Register Name: SPI_FCR                               |
|----------------|------------|-------------|------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                          |
|                |            |             | 1: Enable                                            |
| 7:0            | R/W        | 0x1         | RX_TRIG_LEVEL<br>RX FIFO Ready Request Trigger Level |

#### 8.16.6.6 0x001C SPI FIFO Status Register (Default Value: 0x0000\_0000)

| Offset: 0x001C |            |             | Register Name: SPI_FSR                                                                                                                                                               |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                          |
| 31             | R          | 0x0         | TB_WR<br>TX FIFO Write Buffer Write Enable                                                                                                                                           |
| 30:24          | /          | /           | /                                                                                                                                                                                    |
| 23:16          | R          | 0x0         | TF_CNT<br>TX FIFO Counter<br>These bits indicate the number of words in TX FIFO<br>0: 0 byte in TX FIFO<br>1: 1 byte in TX FIFO<br>...<br>64: 64 bytes in TX FIFO<br>other: Reserved |
| 15             | R          | 0x0         | RB_WR<br>RX FIFO Read Buffer Write Enable                                                                                                                                            |
| 14:8           | /          | /           | /                                                                                                                                                                                    |
| 7:0            | R          | 0x0         | RF_CNT<br>RX FIFO Counter<br>These bits indicate the number of words in RX FIFO<br>0: 0 byte in RX FIFO<br>1: 1 byte in RX FIFO<br>...<br>64: 64 bytes in RX FIFO<br>other: Reserved |

#### 8.16.6.7 0x0020 SPI Wait Clock Counter Register (Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: SPI_WCR                                                                                     |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                |
| 31:20          | /          | /           | /                                                                                                          |
| 19:16          | R/W        | 0x0         | SWC<br>Dual mode direction switch wait clock counter (for master mode only).<br>0: No wait states inserted |

| Offset: 0x0020 |            |             | Register Name: SPI_WCR                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                |
|                |            |             | <p>n: n SPI_SCLK wait states inserted<br/>                     These bits control the number of wait states to be inserted before start dual data transfer in dual SPI mode. The SPI module counts SPI_SCLK by SWC for delaying next word data transfer.</p> <p><b>Note:</b> Can't be written when XCH=1.</p>                                                                                              |
| 15:0           | R/W        | 0x0         | <p>WCC<br/>                     Wait Clock Counter (In Master mode)<br/>                     These bits control the number of wait states to be inserted in data transfers. The SPI module counts SPI_SCLK by WCC for delaying next word data transfer.</p> <p>0: No wait states inserted<br/>                     N: N SPI_SCLK wait states inserted</p> <p><b>Note:</b> Can't be written when XCH=1.</p> |

#### 8.16.6.8 0x0028 SPI Sample Delay Control Register (Default Value: 0x0000\_2000)

| Offset: 0x0028 |            |             | Register Name: SPI_SAMP_DL                                                                                                                                                                                                                                                                                    |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                   |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                             |
| 7              | R/W        | 0x0         | <p>SAMP_DL_SW_EN<br/>                     Sample Delay Software Enable<br/>                     When set, enable sample delay specified at SAMP_DL_SW</p>                                                                                                                                                     |
| 6              | /          | /           | /                                                                                                                                                                                                                                                                                                             |
| 5:0            | R/W        | 0x0         | <p>SAMP_DL_SW<br/>                     Sample Delay Software<br/>                     The relative delay between clock line and command line, data lines.<br/>                     It can be determined according to the value of SAMP_DL, the cycle of card clock and device's input timing requirement.</p> |

#### 8.16.6.9 0x0030 SPI Master Burst Counter Register (Default Value: 0x0000\_0000)

| Offset: 0x0030 |            |             | Register Name: SPI_MBC |
|----------------|------------|-------------|------------------------|
| Bit            | Read/Write | Default/Hex | Description            |
| 31:24          | /          | /           | /                      |
| 23:0           | R/W        | 0x0         | MBC                    |

| Offset: 0x0030 |            |             | Register Name: SPI_MBC                                                                                                                                                                                                                                                                                                        |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                   |
|                |            |             | <p>Master Burst Counter<br/>In master mode, this field specifies the total burst number.<br/>0: 0 burst<br/>1: 1 burst<br/>...<br/>N: N bursts</p> <p><b>Note:</b></p> <ul style="list-style-type: none"> <li>• Can't be written when XCH=1;</li> <li>• Total transfer data, include the TXD, RXD and dummy burst.</li> </ul> |

#### 8.16.6.10 0x0034 SPI Master Transmit Counter Register (Default Value: 0x0000\_0000)

| Offset: 0x0034 |            |             | Register Name: SPI_MTC                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                               |
| 31:24          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                         |
| 23:0           | R/W        | 0x0         | <p>MWTC<br/>Master Write Transmit Counter<br/>In master mode, this field specifies the burst number that should be sent to TXFIFO before automatically sending dummy burst. For saving bus bandwidth, the dummy burst (all zero bits or all one bits) is sent by SPI Controller automatically.<br/>0: 0 burst<br/>1: 1 burst<br/>...<br/>N: N bursts</p> <p><b>Note:</b> Can't be written when XCH=1.</p> |

#### 8.16.6.11 0x0038 SPI Master Burst Control Counter Register (Default Value: 0x0000\_0000)

| Offset: 0x0038 |            |             | Register Name: SPI_BCC                                                                               |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                          |
| 31: 30         | /          | /           | /                                                                                                    |
| 29             | R/W        | 0x0         | <p>Quad_EN<br/>Quad_Mode_EN<br/>0: Quad mode disable<br/>1: Quad mode enable</p> <p><b>Note:</b></p> |

| Offset: 0x0038 |            |             | Register Name: SPI_BCC                                                                                                                                                                                                                                                                                                                             |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                        |
|                |            |             | <ul style="list-style-type: none"> <li>• Can't be written when XCH=1;</li> <li>• Quad mode includes Quad-Input and Quad-Output.</li> </ul>                                                                                                                                                                                                         |
| 28             | R/W        | 0x0         | <p>DRM<br/>Master Dual Mode RX Enable<br/>0: RX use single-bit mode<br/>1: RX use dual mode</p> <p><b>Note:</b></p> <ul style="list-style-type: none"> <li>• Can't be written when XCH=1.</li> <li>• It is only valid when Quad_Mode_EN=0.</li> </ul>                                                                                              |
| 27:24          | R/W        | 0x0         | <p>DBC<br/>Master Dummy Burst Counter<br/>In master mode, this field specifies the burst number that should be sent before receive in dual SPI mode.<br/>The data is don't care by the device.<br/>0: 0 burst<br/>1: 1 burst<br/>...<br/>N: N bursts</p> <p><b>Note: Can't be written when XCH=1.</b></p>                                          |
| 23:0           | R/W        | 0x0         | <p>STC<br/>Master Single Mode Transmit Counter<br/>In master mode, this field specifies the burst number that should be sent in single mode before automatically sending dummy burst. This is the first transmit counter in all bursts.<br/>0: 0 burst<br/>1: 1 burst<br/>...<br/>N: N bursts</p> <p><b>Note: Can't be written when XCH=1.</b></p> |

#### 8.16.6.12 0x0040 SPI Bit-Aligned Transfer Configure Register (Default Value: 0x0000\_00A0)

| Offset: 0x0040 |            |             | Register Name: SPI_BATCR                                                                                                                                              |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                           |
| 31             | R/WAC      | 0x0         | <p>TCE<br/>Transfer Control Enable<br/>In master mode, it is used to start t1o transfer the serial bits frame, it is only valid when Work Mode Select==0x10/0x11.</p> |

| Offset: 0x0040 |            |             | Register Name: SPI_BATCR                                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                              |
|                |            |             | <p>0: Idle<br/>1: Initiates transfer.<br/>Write “1” to this bit will start to transfer serial bits frame (the value comes from the SPI TX Bit Register or SPI RX Bit Register), and will auto clear after the bursts transfer completely. Write ‘0’ to this bit has no effect.</p>                                                                                       |
| 30             | R/W        | 0x0         | <p>MSMS<br/>Master Sample Standard<br/>0: Standard Sample Mode<br/>1: Delay Sample Mode<br/>In Standard Sample Mode, SPI master samples the data at the standard rising edge of SCLK for each SPI mode.<br/>In Delay Sample Mode, SPI master samples data at the edge that is half cycle delayed by the standard rising edge of SCLK defined in respective SPI mode.</p> |
| 29:26          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                        |
| 25             | R/W1C      | 0x0         | <p>TBC<br/>Transfer Bits Completed<br/>When set, this bit indicates that the last bit of the serial data frame in SPI TX Bit Register(or SPI RX Bit Register) has been transferred completely. Writing 1 to this bit clears it.<br/>0: Busy<br/>1: Transfer Completed<br/><b>Note: It is only valid when Work Mode Select==0x10/0x11.</b></p>                            |
| 24             | R/W        | 0x0         | <p>TBC_INT_EN<br/>Transfer Bits Completed Interrupt Enable<br/>0: Disable<br/>1: Enable<br/><b>Note: It is only valid when Work Mode Select==0x10/0x11.</b></p>                                                                                                                                                                                                          |
| 23:22          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                        |
| 21:16          | R/W        | 0x00        | <p>RX_FEM_LEN<br/>Configure the length of serial data frame(burst) of RX<br/>000000: 0bit<br/>000001: 1bit<br/>...<br/>100000: 32bits</p>                                                                                                                                                                                                                                |

| Offset: 0x0040 |            |             | Register Name: SPI_BATCR                                                                                                                                                                                                                                                                                                                                                                             |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                          |
|                |            |             | Other values: reserved<br><b>Note:</b> It is only valid when Work Mode<br>Select==0x10/0x11, and can't be written when TCE=1.                                                                                                                                                                                                                                                                        |
| 15:14          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                    |
| 13:8           | R/W        | 0x00        | TX_FEM_LEN<br>Configure the length of serial data frame(burst) of TX<br>000000: 0bit<br>000001: 1bit<br>...<br>100000: 32bits<br>Other values: reserved<br><b>Note:</b> It is only valid when Work Mode<br>Select==0x10/0x11, and can't be written when TCE=1.                                                                                                                                       |
| 7              | R/W        | 0x1         | SS_LEVEL<br>When control SS signal manually, set this bit to '1' or '0' to control the level of SS signal.<br>0: set SS to low<br>1: set SS to high<br><b>Note:</b> It is only valid when Work Mode<br>Select==0x10/0x11, and only work in Mode0, can't be written when TCE=1.                                                                                                                       |
| 6              | R/W        | 0x0         | SS_OWNER<br>SS Output Owner Select<br>Usually, controller sends SS signal automatically with data together. When this bit is set to 1, software must manually write SPI_CTL_REG.SS_LEVEL to 1 or 0 to control the level of SS signal.<br>0: SPI controller<br>1: Software<br><b>Note:</b> It is only valid when Work Mode<br>Select==0x10/0x11, and only work in Mode0, can't be written when TCE=1. |
| 5              | R/W        | 0x1         | SPOL<br>SPI Chip Select Signal Polarity Control<br>0: Active high polarity (0 = Idle)<br>1: Active low polarity (1 = Idle)<br><b>Note:</b> It is only valid when Work Mode<br>Select==0x10/0x11, and only work in Mode0, can't be written when TCE=1.                                                                                                                                                |
| 4              | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                    |
| 3:2            | R/W        | 0x0         | SS_SEL                                                                                                                                                                                                                                                                                                                                                                                               |

| Offset: 0x0040 |            |             | Register Name: SPI_BATCR                                                                                                                                                                                                                                                                                                                     |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                  |
|                |            |             | <p>SPI Chip Select<br/>Select one of four external SPI Master/Slave Devices<br/>00: SPI_SS0 will be asserted<br/>01: SPI_SS1 will be asserted<br/>10: SPI_SS2 will be asserted<br/>11: SPI_SS3 will be asserted<br/><b>Note: It is only valid when Work Mode Select==0x10/0x11, and only work in Mode0, can't be written when TCE=1.</b></p> |
| 1:0            | R/W        | 0x0         | <p>WMS<br/>Work Mode Select<br/>00: Data frame is byte aligned in Standard SPI, Dual-Output/Dual Input SPI, Dual IO SPI and Quad-Output/Quad-Input SPI.<br/>01: Reserve<br/>10: Data frame is bit aligned in 3-Wire SPI<br/>11: Data frame is bit aligned in Standard SPI</p>                                                                |

#### 8.16.6.13 0x0048 SPI TX Bit Register (Default Value: 0x0000\_0000)

| Offset: 0x0048 |            |             | Register Name: SPI_TBR                                                                                                                                                                                                                                                        |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                   |
| 31:0           | R/W        | 0x0         | <p>VTB<br/>The Value of the Transmit Bits<br/>This register is used to store the value of the transmitted serial data frame. In the process of transmission, the LSB is transmitted first.<br/><b>Note: This register is only valid when Work Mode Select==0x10/0x11.</b></p> |

#### 8.16.6.14 0x004C SPI RX Bit Register (Default Value: 0x0000\_0000)

| Offset: 0x004C |            |             | Register Name: SPI_RBR                                                                                                                                                                                                                                 |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                            |
| 31:0           | R/W        | 0x0         | <p>VRB<br/>The Value of the Receive Bits<br/>This register is used to store the value of the received serial data frame. In the process of transmission, the LSB is transmitted first.<br/><b>Note: This register is only valid when Work Mode</b></p> |

| Offset: 0x004C |            |             | Register Name: SPI_RBR |
|----------------|------------|-------------|------------------------|
| Bit            | Read/Write | Default/Hex | Description            |
|                |            |             | Select==0x10/0x11.     |

#### 8.16.6.15 0x0088 SPI Normal DMA Mode Control Register (Default Value: 0x0000\_00E5)

| Offset: 0x0088 |            |             | Register Name: SPI_NDMA_MODE_CTL                                                                                                                                                       |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                            |
| 31:8           | /          | /           | /                                                                                                                                                                                      |
| 7:6            | R/W        | 0x3         | SPI_ACT_M<br>SPI NDMA Active Mode<br>00: DMA_ACTIVE is low<br>01: DMA_ACTIVE is high<br>10: DMA_ACTIVE is controlled by DMA_REQUEST(DRQ)<br>11: DMA_ACTIVE is controlled by controller |
| 5              | R/W        | 0x1         | SPI_ACK_M<br>SPI NDMA Acknowledge Mode<br>0: active fall do not care ack<br>1: active fall must after detect ack is high                                                               |
| 4:0            | R/W        | 0x05        | SPI_DMA_WAIT<br>The counts of hold cycles from DMA last signal high to DMA_ACTIVE high.                                                                                                |

#### 8.16.6.16 0x0100 DBI Control Register 0 (Default Value: 0x0010\_0000)

| Offset: 0x0100 |            |             | Register Name: DBI_CTL_0                                                                                                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                             |
| 31             | R/W        | 0x0         | CMDT<br>Command Type<br>0: Write Command<br>1: Read Command                                                                                                                             |
| 30:20          | R/W        | 0x1         | WCDC<br>Write Command Dummy Cycles<br>Controls dummy cycles between two write commands<br>Range 1-255<br>Default Condition: there is a dbi_clk cycle between each command or parameter. |
| 19             | R/W        | 0x0         | DAT_SEQ<br>Output Data Sequence<br>0: MSB First                                                                                                                                         |

| Offset: 0x0100 |            |             | Register Name: DBI_CTL_0                                                                                                                                                    |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                 |
|                |            |             | 1: LSB First                                                                                                                                                                |
| 18:16          | R/W        | 0x0         | <p>RGB_SEQ<br/>Output RGB Sequence</p> <p>0: RGB<br/>1: RBG<br/>2: GRB<br/>3: GBR<br/>4: BRG<br/>5: BGR<br/>6-7 Reserve</p>                                                 |
| 15             | R/W        | 0x0         | <p>TRAN_MOD<br/>Transmit Mode</p> <p>0: Command / Parameter<br/>1: Video</p>                                                                                                |
| 14:12          | R/W        | 0x0         | <p>DAT_FMT<br/>Output Data Format</p> <p>0 : RGB111<br/>1 : RGB444<br/>2 : RGB565<br/>3 : RGB666<br/>4 : RGB888 ( only for 2 Data Lane Interface )<br/>5-7 Reserve</p>      |
| 11             | /          | /           | /                                                                                                                                                                           |
| 10:8           | R/W        | 0x0         | <p>DBI_INTF<br/>DBI Interface</p> <p>0: 3 Line Interface I<br/>1: 3 Line Interface II<br/>2: 4 Line Interface I<br/>3: 4 Line Interface II<br/>4: 2 Data Lane Interface</p> |
| 7:4            | R/W        | 0x0         | <p>RGB_FMT<br/>RGB_Source_Format</p> <p>When Video Source_Type is RGB32</p> <p>0: RGB<br/>1: RBG<br/>2: GRB<br/>3: GBR<br/>4: BRG<br/>5: BGR<br/>Other:Reserve</p>          |

| Offset: 0x0100 |            |             | Register Name: DBI_CTL_0                                                                                                                                                                                                                                        |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                     |
|                |            |             | When Video Source_Type is RGB16<br>0: RGB<br>1-4:reserve<br>5: BGR<br>6: GRBG_0:{G[5:3] R[4:0] B[4:0] G[2:0]}<br>7: GBRG_0:{G[5:3] B[4:0] R[4:0] G[2:0]}<br>8: GRBG_1:{G[2:0] R[4:0] B[4:0] G[5:3]}<br>9: GBRG_1:{G[2:0] B[4:0] R[4:0] G[5:3]}<br>Other:Reserve |
| 3              | R/W        | 0x0         | DUM_VAL<br>Dummy Cycle Value<br>Output Value During Dummy Cycle                                                                                                                                                                                                 |
| 2              | R/W        | 0x0         | RGB_BO<br>RGB Bit Order<br>0: Remain the sequence of RGB data<br>1: Swap the higher bit and the lower bit for each component of DRAM RGB                                                                                                                        |
| 1              | R/W        | 0x0         | ELEMENT_A_POS<br>Element A Position<br>Only for RGB32 Data Format<br>0: A component is in the bit [31:24] of data source<br>1: A component is in the bit [7:0] of data source                                                                                   |
| 0              | R/W        | 0x0         | VI_SRC_TYPE<br>RGB Source Type<br>0: RGB32<br>1: RGB16                                                                                                                                                                                                          |

#### 8.16.6.17 0x0104 DBI Control Register 1 (Default Value: 0x0000\_0001)

| Offset: 0x0104 |            |             | Register Name: DBI_CTL_1                                                                                                                                                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                       |
| 31             | R/WAC      | 0x0         | DBI_SOFT_TRG<br>It is only available for software trigger mode. Write '1' to this bit will start DBI TX module and auto clear to '0' when completing start operation, write to '0' has no effect. |
| 30:29          | R/W        | 0x0         | DBI_EN_MOD_SEL<br>DBI Enable Mode Select<br>0: always on mode<br>1: software trigger mode<br>2: timer trigger mode                                                                                |

| Offset: 0x0104 |            |             | Register Name: DBI_CTL_1                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                |            |             | 3: te trigger mode                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 28             | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 27:26          | R/W        | 0x0         | RGB666_FMT<br>2 Data Lane RGB666 Format<br>00: Normal Format<br>01: Special Format for ILITEK<br>10: Special Format for New Vision                                                                                                                                                                                                                                                                                                                                               |
| 25             | R/W        | 0x0         | DBI_RXCLK_INV<br>DBI rx clock inverse<br>0: Sample data by using the positive edge of the output clock<br>1: Sample data by using the negative edge of the output clock                                                                                                                                                                                                                                                                                                          |
| 24             | R/W        | 0x0         | DBI_CLKO_MOD<br>DBI output clock mode<br>0: DBI clock always on(DCX Setup/hold equals one clock cycle)<br>1: DBI clock auto gating(DCX Setup/hold equals to a half clock cycle)                                                                                                                                                                                                                                                                                                  |
| 23             | R/W        | 0x0         | DBI_CLKO_INV<br>DBI clock output inverse<br>When the bit24 (DBI output clock mode) is 0.<br>0: The falling edge releases the CSX signal, and the falling edge releases data<br>1: The rising edge releases the CSX signal, and the rising edge releases data<br>When the bit24 (DBI output clock mode) is 1.<br>0: The rising edge releases the CSX signal, and the falling edge releases data<br>1: The falling edge releases the CSX signal, and the rising edge releases data |
| 22             | R/W        | 0x0         | DCX_DATA<br>DCX Data Value<br>0: DCX Value equal to 0<br>1: DCX Value equal to 1                                                                                                                                                                                                                                                                                                                                                                                                 |
| 21             | R/W        | 0x0         | RGB 16 Data Source Select<br>RGB 16 Data Source Select<br>0: Pixel1 is stored in the higher bit of address, and Pixel0 is stored in the lower bit of address<br>1: Pixel0 is stored in the higher bit of address, and Pixel1 is stored in the lower bit of address                                                                                                                                                                                                               |

| Offset: 0x0104 |            |             | Register Name: DBI_CTL_1                                                                                                                         |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                      |
| 20             | R/W        | 0x0         | RDAT_LSB<br>Bit Order of Read Data<br>0: A reading data is the higher bit<br>1: A reading data is the lower bit                                  |
| 19:16          | /          | /           | /                                                                                                                                                |
| 15:8           | R/W        | 0x0         | RCDC<br>Read Command Dummy Cycles<br>The dummy cycle between the read command and read data<br>Reading 1-byte (8 bits) data has not dummy cycle. |
| 7:0            | R/W        | 0x1         | RDBN<br>Read Data Number of Bytes<br>Sample Bytes data based on configuration.                                                                   |

#### 8.16.6.18 0x0108 DBI Control Register 2 (Default Value: 0x0000\_4000)

| Offset: 0x0108 |            |             | Register Name: DBI_CTL_2                                                                                                                                                                                  |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                               |
| 31:16          | /          | /           | /                                                                                                                                                                                                         |
| 15             | R/W        | 0x0         | DBI_FIFO_DRQ_EN<br>DBI FIFO DMA Request Enable<br>0: Disable<br>1: Enable                                                                                                                                 |
| 14:8           | R/W        | 0x40        | DBI_TRIG_LEVEL<br>DBI FIFO Empty Request Trigger Level                                                                                                                                                    |
| 7              | /          | /           | /                                                                                                                                                                                                         |
| 6              | R/W        | 0x0         | DBI_SDI_OUT_SEL<br>DBI SDI PIN Output Select<br>The signal is used with the DBI SDI PIN Function Sel bit.<br>0: Output WRX (When DBI DCX PIN Function Sel = 0, the SDI pin outputs data)<br>1: Output DCX |
| 5              | R/W        | 0x0         | DBI_DCX_SEL<br>DBI DCX PIN Function Sel<br>0: DBI DCX Function<br>1:WRX(2 Data Lane Interface)                                                                                                            |
| 4:3            | R/W        | 0x0         | DBI_SDI_SEL<br>DBI SDI PIN Function sel<br>0: DBI_SDI ( Interface II ), WRX(2 Data Lane Interface)                                                                                                        |

| Offset: 0x0108 |            |             | Register Name: DBI_CTL_2                                                         |
|----------------|------------|-------------|----------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                      |
|                |            |             | 1: DBI_TE<br>2: DBI_DCX<br>Reserve                                               |
| 2              | R/W        | 0x0         | TE_DBC_SEL<br>TE debounce function select<br>0: debounce<br>1: no-debounce       |
| 1              | R/W        | 0x0         | TE_TRIG_SEL<br>TE edge trigger select<br>0: TE rising edge<br>1: TE falling edge |
| 0              | R/W        | 0x0         | TE_EN<br>TE enable<br>0: TE Disable<br>1: TE Enable                              |

#### 8.16.6.19 0x010C DBI Timer Control Register (Default Value: 0x0000\_0000)

| Offset: 0x010C |            |             | Register Name: DBI_TIMER                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 31             | R/W        | 0x0         | DBI_TM_EN<br>DBI Timer enable<br>0: enable<br>1: disable                                                                                                                                                                                                                                                                                                                                                                                                 |
| 30:0           | R/W        | 0x0         | DBI Timer Value<br>It sets the time interval between sending data twice, which is frame blanking.<br>It is used to set the time at which the interrupt of the DBI Timer is triggered. When the Timer_EN is 1, the timer starts to count (the clock of the counting is SCLK), and the counter reaches the target value to trigger the Timer_INT of DBI, the data will start to send in series.<br><b>Note: Do not count when sending the series data.</b> |

#### 8.16.6.20 0x0110 DBI Video Size Register (Default Value: 0x01e0\_0140)

| Offset: 0x0110 |            |             | Register Name: DBI_VIDEO_SIZE |
|----------------|------------|-------------|-------------------------------|
| Bit            | Read/Write | Default/Hex | Description                   |
| 31:27          | /          | /           | /                             |

| Offset: 0x0110 |            |             | Register Name: DBI_VIDEO_SIZE                   |
|----------------|------------|-------------|-------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                     |
| 26:16          | R/W        | 0x1e0       | V_SIZE<br>It is used to generate the Frame int. |
| 15:11          | /          | /           | /                                               |
| 10:0           | R/W        | 0x140       | H_SIZE<br>It is used to generate the Line int.  |

#### 8.16.6.21 0x0120 DBI Interrupt Register (Default Value: 0x0000\_4000)

| Offset: 0x0120 |            |             | Register Name: DBI_INT                                                                                                                                                                                                       |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                  |
| 31:15          | /          | /           | /                                                                                                                                                                                                                            |
| 14             | R/W1C      | 0x1         | DBI_FIFO_EMPTY_INT<br>DBI FIFO Empty Interrupt Status<br>0: DBI_FIFO is not empty<br>1: DBI_FIFO is empty                                                                                                                    |
| 13             | R/W1C      | 0x0         | DBI_FIFO_FULL_INT<br>DBI FIFO Full Interrupt Status<br>0: DBI_FIFO is not full<br>1: DBI_FIFO is full                                                                                                                        |
| 12             | R/W1C      | 0x0         | TIMER_INT<br>it indicates that timer has been count sclk cycles to the value of DBI_Timer Register[30:0] . Writing 1 to this bit clears it.<br>0: Timer has no been achieve objective<br>1: Timer has been achieve objective |
| 11             | R/W1C      | 0x0         | RD_DONE_INT<br>it indicates that the number of byte setting in DBI_Control Register 1 [19:8] has been read . Writing 1 to this bit clears it.<br>0: all of data has been not read<br>1: all of data has been read            |
| 10             | R/W1C      | 0x0         | TE_INT<br>it indicates that TE signal has been changed. Writing 1 to this bit clears it.<br>0: TE signal is no changed<br>1: TE signal has been changed                                                                      |
| 9              | R/W1C      | 0x0         | FRAM_DONE_INT<br>it indicates that a frame video data has been send. Writing 1 to this bit clears it.<br>0: a frame video has not been send<br>1: a frame video has been send                                                |

| Offset: 0x0120 |            |             | Register Name: DBI_INT                                                                                                                                                                        |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                   |
| 8              | R/W1C      | 0x0         | LINE_DONE_INT<br>it indicates that a line of video data has been send. Writing 1 to this bit clears it.<br>0: a line of video data has not been send<br>1: a line of video data has been send |
| 7              | /          | /           | /                                                                                                                                                                                             |
| 6              | R/W        | 0x0         | DBI_FIFO_EMPTY_INT_EN<br>DBI FIFO Empty Interrupt Enable<br>0: Disable<br>1: Enable                                                                                                           |
| 5              | R/W        | 0x0         | DBI_FIFO_FULL_INT_EN<br>DBI FIFO Full Interrupt Enable<br>0: Disable<br>1: Enable                                                                                                             |
| 4              | R/W        | 0x0         | TIMER_INT_EN<br>Timer Interrupt Enable<br>0: Disable<br>1: Enable                                                                                                                             |
| 3              | R/W        | 0x0         | RD_DONE_INT_EN<br>Read Done Interrupt Enable<br>0: Disable<br>1: Enable                                                                                                                       |
| 2              | R/W        | 0x0         | TE_INT_EN<br>TE Interrupt Enable<br>0: Disable<br>1: Enable                                                                                                                                   |
| 1              | R/W        | 0x0         | FRAM_DONE_INT_EN<br>Frame Done Interrupt Enable<br>0: Disable<br>1: Enable                                                                                                                    |
| 0              | R/W        | 0x0         | LINE_DONE_INT_EN<br>Line Done Interrupt Enable<br>0: Disable<br>1: Enable                                                                                                                     |

#### 8.16.6.22 0x0124 DBI Debug Register 0 (Default Value: 0x007F\_0000)

| Offset: 0x0124 |            |             | Register Name: DBI_DEBUG_0 |
|----------------|------------|-------------|----------------------------|
| Bit            | Read/Write | Default/Hex | Description                |
| 31:23          | /          | /           | /                          |
| 22:16          | R          | 0x7F        | DBI_FIFO_AVAIL             |

| Offset: 0x0124 |            |             | Register Name: DBI_DEBUG_0                                                    |
|----------------|------------|-------------|-------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                   |
|                |            |             | DBI FIFO ROOM VALID<br>0-127 Words                                            |
| 15:13          | /          | /           | /                                                                             |
| 12             | R          | 0x0         | TE_VAL<br>TE input value<br>0 : TE not Trigger<br>1 : TE Trigger              |
| 11:8           | R          | 0x0         | DBI_RXCS<br>FSM for DBI Receive<br>RX_BS0 - RX_BS6 , Gray - Code              |
| 7:4            | R          | 0x0         | SH_CS<br>FSM for shifter<br>0-11 : SH0-SH11                                   |
| 3:2            | R          | 0x0         | DBI_TXCS<br>FSM for DBI Transmit<br>0: IDLE<br>1: SHIF<br>2: DUMMY<br>3: READ |
| 1:0            | R          | 0x0         | MEM_CS<br>FSM for DBI Memory<br>0: IDLE_FRM<br>1: FRM_POS<br>2: FRM_RDY       |

#### 8.16.6.23 0x0128 DBI Debug Register 1 (Default Value: 0x0000\_0000)

| Offset: 0x0128 |            |             | Register Name: DBI_DEBUG_1                                                                                               |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                              |
| 31:26          | /          | /           | /                                                                                                                        |
| 25:16          | R          | 0x0         | LCNT<br>Line counter<br>The number of pixel lines that are currently sent                                                |
| 15:12          | /          | /           | /                                                                                                                        |
| 11:0           | R          | 0x0         | CCNT<br>Component counter<br>The number of RGB components that are currently sent<br>The field is equal to pixel_cnt *3. |

#### 8.16.6.24 0x0200 SPI TX Data Register (Default Value: 0x0000\_0000)

| Offset: 0x0200 |            |             | Register Name: SPI_TXD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 31:0           | R/W        | 0x0         | <p>TDATA<br/>Transmit Data</p> <p>This register can be accessed in byte, half-word or word unit by AHB. In byte accessing method, if there are rooms in TXFIFO, one burst data is written to TXFIFO and the depth is increased by 1. In half-word accessing method, two SPI burst data are written and the TXFIFO depth is increase by 2. In word accessing method, four SPI burst data are written and the TXFIFO depth is increased by 4.</p> <p><b>Note:</b> This address is writing-only if TF_TEST is '0', and if TF_TEST is set to '1', this address is readable and writable to test the TX FIFO through the AHB bus.</p> |

#### 8.16.6.25 0x0300 SPI RX Data Register (Default Value: 0x0000\_0000)

| Offset: 0x0300 |            |             | Register Name: SPI_RXD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 31:0           | R          | 0x0         | <p>RDATA<br/>Receive Data</p> <p>This register can be accessed in byte, half-word or word unit by AHB. In byte accessing method, if there are data in RXFIFO, the top word is returned and the RXFIFO depth is decreased by 1. In half-word accessing method, two SPI bursts are returned and the RXFIFO depth is decrease by 2. In word accessing method, the four SPI bursts are returned and the RXFIFO depth is decreased by 4.</p> <p><b>Note:</b> This address is read-only if RF_TEST is '0', and if RF_TEST is set to '1', this address is readable and writable to test the RX FIFO through the AHB bus.</p> |

#### 8.16.6.26 0x0400 SPI BUF Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0400 |            |             | Register Name: SPI_BSR |
|----------------|------------|-------------|------------------------|
| Bit            | Read/Write | Default/Hex | Description            |
| 31:19          | /          | /           | /                      |
| 18:16          | R          | 0x0         | TB_CNT                 |

| Offset: 0x0400 |            |             | Register Name: SPI_BSR                                                                                  |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                             |
|                |            |             | TX FIFO Write Buffer Counter<br>These bits indicate the number of words in TX FIFO Write Buffer         |
| 15:8           | /          | /           | /                                                                                                       |
| 7:0            | R          | 0x0         | RB_CNT<br>RX FIFO Read Buffer Counter<br>These bits indicate the number of words in RX FIFO Read Buffer |



## 8.17 SPI Flash controller (SPIFC)

### 8.17.1 Overview

The SPI Flash Controller (SPIFC) is a synchronous, serial communication interface which allows rapid data communication with fewer software interrupts. Different from SPI, this IP is typically designed for higher speed Flash devices and it only works at Master mode.

The SPI Flash Controller has the following features:

- Supports multiple SPI modes
  - Standard SPI
  - Dual-Input/Dual-Output SPI and Dual-I/O SPI
  - Quad-Input/Quad-Output SPI, Quad-I/O SPI, and QPI
  - Octal-Input/Octal-Output SPI, Octal-I/O SPI, and OPI
  - 3-wire SPI with programmable serial data frame length of 1 bit to 32 bits
- Supports STR mode and DTR mode, and DTR mode supports DQS signal
- High Speed Clock Frequency
  - 150MHz for STR Mode
  - 100MHz for DTR Mode
- Software Write Protection
  - Write protection for all/portion of memory via software
  - Top/Bottom Block protection
- Programmable delay between transactions
- Supports Mode0, Mode1, Mode2 and Mode3
- Supports control signal configuration
  - Up to four chip selects to support multiple peripherals
  - Polarity and phase of the Chip Select (SPI\_SS) and SPI Clock (SPI\_SCLK) are configurable

### 8.17.2 Block Diagram

The following figure shows a block diagram of the SPI Flash Controller.

**Figure 8-106 SPI\_Flash Block Diagram**



SPI Flash Controller contains the following sub-blocks:

**Table 8-53 SPI Flash Controller Sub-blocks**

| Sub-block         | Description                                                                                                                                                                                                                                                                                                                                  |
|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SPI_Register_File | Responsible for implementing registers configuration through AHB1 bus.                                                                                                                                                                                                                                                                       |
| SPI_Private_DMA   | Private DMA for SPI, which contains AHB master and supports TXFIFO(WR_FIFO) and RXFIFO(RD_FIFO).                                                                                                                                                                                                                                             |
| CMU               | Responsible for generating internal clock; Implementing sckr delay, clock source selection, clock gating, and scan; supporting synchronous release of asynchronous reset and scan.                                                                                                                                                           |
| SPI_CDC           | SPI cross-clock module, in which bit width transition finishes. (TX: 32bit->8bit; RX: 8bit->32bit)<br>WR_BUF: Cache the write SPI data of AHB, and write them to WR_FIFO.<br>RD_BUF: Cache the read SPI data of RD_FIFO to AHB.<br>WR_FIFO: SPI write data FIFO (SRAM 32x32)<br>RD_FIFO: SPI read data FIFO (SRAM 32x32) in the normal mode. |
| SPI_Controller    | SPI controlling center. It generates TX/RX controlling signal in the course of SPI communication.                                                                                                                                                                                                                                            |
| SPI_Interface     | Standard SPI interface. It is responsible for receiving and transmitting data with Devices.                                                                                                                                                                                                                                                  |

| Sub-block | Description                               |
|-----------|-------------------------------------------|
| SPI_bit   | the processing module in SPI 3-wire mode. |

### 8.17.3 Functional Description

#### 8.17.3.1 External Signals

The following table describes the external signals of SPI Flash Controller. When using SPI Flash Controller, the corresponding PADs are selected as SPI Flash Controller function via section 8.5 GPIO.

**Table 8-54 SPI Flash Controller External Signals**

| Signal Name | Description                                   | Type |
|-------------|-----------------------------------------------|------|
| SPIF-CS0    | SPI Peripheral Chip Select Signal, Low Active | O    |
| SPIF-CLK    | SPI Master Mode Clock Output                  | O    |
| SPIF-MOSI   | SPI Master Data Out, Slave Data In            | I/O  |
| SPIF-MISO   | SPI Master Data In, Slave Data Out            | I/O  |
| SPIF-DQS    | Data Strobe Signal                            | I    |
| SPIF-D[7:4] | SPI Master Mode Data in Octal Mode            | I/O  |
| SPIF-WP     | SPI Write Protect, Low Active                 | I/O  |
| SPIF-HOLD   | SPI Hold Signal                               | I/O  |

#### 8.17.3.2 Clock Sources

The SPI\_Flash controller gets 5 different clock sources and users can select one of them to make SPI Flash Controller clock source. The following table describes the clock sources for SPI Flash Controller. For more details on the clock setting, configuration, and gating information, see section 2.5 Clock Controller Unit (CCU).

**Table 8-55 SPI Flash Controller Clock Sources**

| Clock sources | Description                                 | Clock module |
|---------------|---------------------------------------------|--------------|
| HOSC          | 24 MHz Crystal                              | CCU          |
| PERI0_400M    | Peripheral Clock, default value is 400 MHz. |              |
| PERI0_300M    | Peripheral Clock, default value is 300 MHz. |              |
| PERI1_400M    | Peripheral Clock, default value is 400 MHz. |              |
| PERI1_300M    | Peripheral Clock, default value is 300 MHz. |              |

### 8.17.3.3 Typical Application

The following figure shows the application block diagram when the SPI master device is connected to a slave device.

Figure 8-107 Typical Application



The SPI Flash Controller is running in Master device. SPI\_SCK is generated and transmitted to external device. The data from the TX FIFO is routed to the MOSI pin. The data from slave is received on the MISO pin and sent to RX FIFO. Chip Select(SPI\_CS) signal is active in low level. SPI\_CS must be set to low before data are transmitted or received.

### 8.17.3.4 SPI Flash Controller feature list

Table 8-56 SPI Flash Controller Feature List

| SPI mode     |         | Feature List |     |            |                                                                                           |              |                                                                                                                             |
|--------------|---------|--------------|-----|------------|-------------------------------------------------------------------------------------------|--------------|-----------------------------------------------------------------------------------------------------------------------------|
|              |         | STR          | DTR | DTR-RX-DQS | SCK_MODE                                                                                  | Address Size | Description                                                                                                                 |
| Bit Mode     | 3-wire  | √            | ✗   | ✗          | mode0                                                                                     | ✗            | /                                                                                                                           |
|              | 4-wire  |              |     |            |                                                                                           |              |                                                                                                                             |
| Standard SPI | 1-1-1-1 | √            | √   | √          | <ul style="list-style-type: none"> <li>mode 0/1/2/3 (STR)</li> <li>mode0 (DTR)</li> </ul> | 24bit/32bit  | <ul style="list-style-type: none"> <li>1-1-1-1: cmd-addr-mod e-data.</li> <li>mode is optional and can be turned</li> </ul> |

| SPI mode  |         | Feature List |     |            |          |              |                                                                    |
|-----------|---------|--------------|-----|------------|----------|--------------|--------------------------------------------------------------------|
|           |         | STR          | DTR | DTR-RX-DQS | SCK_MODE | Address Size | Description                                                        |
|           |         |              |     |            |          |              | off.                                                               |
| Dual SPI  | 1-1-1-2 | √            | √   | √          |          |              |                                                                    |
|           | 1-1-2-2 |              |     |            |          |              |                                                                    |
|           | 1-2-2-2 |              |     |            |          |              |                                                                    |
|           | 2-2-2-2 |              |     |            |          |              |                                                                    |
| Quad SPI  | 1-1-1-4 | √            | √   | √          |          |              |                                                                    |
|           | 1-1-4-4 |              |     |            |          |              |                                                                    |
|           | 1-4-4-4 |              |     |            |          |              |                                                                    |
|           | 4-4-4-4 |              |     |            |          |              |                                                                    |
| Octal SPI | 1-1-1-8 | √            | √   | √          |          |              | 8-wire DTR only supports the following:<br>ADDR-24+MODE<br>ADDR-32 |
|           | 1-1-8-8 |              |     |            |          |              |                                                                    |
|           | 1-8-8-8 |              |     |            |          |              |                                                                    |
|           | 8-8-8-8 |              |     |            |          |              |                                                                    |

### 8.17.3.5 SPI Flash Controller Clock

SPI includes two clock domains: ahb\_clk and spi\_clk:

- The functions in ahb\_clk: parameter analysis (ahb\_register) and DMA.
- The functions in spi\_clk: cross domain clock, main control unit, the communication between SPI-TX/RX and external devices.

The clock management unit (CMU) divides the external SPI reference clock and gets the o\_spi\_clk as the internal clock. Based on the clock properties configured by the CPU, the sckt/sckr is gotten to be used as communication clocks for the SPI\_TX\_INTERFACE/SPI\_RX\_INTERFACE.

The clock properties include:

- SPI Clock Mode
- DQS EN
- STR or DTR

When the SPI runs at a higher clock frequency, sckr may sample the wrong data because of lane delay. Thus, before sampling, the sckr should be processed by the receive clock latency.

## SPI Flash Controller Clock Mode

The SPI Flash controller supports 4 different modes for data transfer. Software can select one of the four modes in which the SPI works by setting the bit5(SPI\_CPOL) and bit4(SPI\_CPHA) of [SPI Global Control Register](#)[0x0004].

The SPI\_CPOL defines the signal polarity when SPI\_SCLK is in the idle state. The SPI\_SCLK is high level when POL is '1' and it is low level when POL is '0'. The SPI\_CPHA decides whether the leading edge of SPI\_SCLK is used for setup or sample data. The leading edge is used for setup data when PHA is '1' and for sample data when PHA is '0'. The four kind of modes are listed Table:

**Table 8-57 SPIFC Modes with Clock Polarity and Phase**

| SPI Mode | POL | PHA | Leading Edge    | Trailing Edge   |
|----------|-----|-----|-----------------|-----------------|
| 0        | 0   | 0   | Rising, Sample  | Falling, Setup  |
| 1        | 0   | 1   | Rising, Setup   | Falling, Sample |
| 2        | 1   | 0   | Falling, Sample | Rising, Setup   |
| 3        | 1   | 1   | Failing, Setup  | Rising, Sample  |

During Phase 0, Polarity 0 and Phase 1, Polarity 1 operations, output data changes on the falling edge and input data is shifted in on the rising edge.

During Phase 1, Polarity 0 and Phase 0, Polarity 1 operations, output data changes on the rising edges and is shifted in on falling edges.

SPI Bit Mode only supports Phase 0, Polarity 0 operation; the most significant bit (MSB) of data is transmitted first which is not configurable.

The following figure describe four waveforms for SPI\_SCLK.

**Figure 8-108 SPI Transfer Mode**



For MSB first

### Single Transfer Rate (STR)

In mode 0 and mode 3, the input data of devices will be latched at the rising edge of SCK, and the output data will be used at the falling edge of SCK.

Figure 8-109 SPI STR Transfer



### Double Transfer Rate (DTR)

As with the STR command, the instruction bit is latched at the rising edge of the clock in the DTR command, but the address and input data are latched at the dual edge. After the instruction bit is latched at the falling edge of SCK, the first address bit will be latched at the next rising edge of SCK. The first output data bit will be sent at the falling edge of the last access latency period.

As with the STR command, the SCK period is the cycle between two adjacent SCK falling edges. In mode 0, the SCK is already at a low level when some command starts to be executed, thus the first SCK period during the command execution indicates the cycle from the falling edge of CS# to the first falling edge of SCK.

Figure 8-110 SPI DTR Transfer Example, 1-4-4



Figure 8-111 SPI DTR Transfer Example, 4-4-4



## DQS

DQS (DATA Strobe Signal) signal indicates input/output data valid for DTR modes and is required to support high-speed data. When data strobe function is enabled, DQS signal is driven to ground once CS# goes LOW till the device is driving output data, in which case DQS toggles to synchronize data output. When data strobe function is not enabled, DQS signal will not be driven.

Figure 8-112 SPI DTR Transfer with DQS Input Clock Signal



### 8.17.3.6 SPI Run Clock and Sample Mode

#### SCKR Delay through Digital Adjustment

To realize the SCKR delay, connect the clk\_gate and clk\_xor in series to control the opening time of the EN terminal of clk\_gate and the polarity of the EN terminal of clk\_xor. The specific steps are as follows:

- Step 1** Enable the EN terminal delay of the first-level clk\_gate module to realize a delay of 1 sclk. (the effective range is 0-3 sclk)
- Step 2** Make the EN terminal of the second-level clk\_xor module differ in polarity to realize a delay of 0.5 sclk. (the effective values are 0 sclk and 0.5 sclk)

#### SCKR Delay through Analog Adjustment

There are delay chains in SPI, used to generate delay to make proper timing between internal SPI clock signal and data signals. Delay chain is made up with 64 delay cells. The delay time of one delay cell can be estimated through delay chain calibration.

Take RX delay chain as an example: the steps to calibrate delay chain are as follows:

- Step 1** Configure a proper clock for the SPI Flash Controller. Calibration delay chain is based on the clock for SPI FLASH CONTROLLER from Clock Controller Unit (CCU)
- Step 2** Set proper initial delay value to ([SPI Timing Configure Register](#), 0x000C). Write 0x60 to this register to set initial delay value 0x20 to delay chain. Then write 0x0 to delay control register to clear this value.
- Step 3** Write 0x80 to [SPI Timing Configure Register](#) to start calibrate delay chain.

- Step 4** Wait until the flag (Bit7 in [SPI Timing Delay State Register](#) 0x0010) of calibration done is set. The number of delay cells is shown at Bit5-Bit0 in [SPI Timing Delay State Register](#). The delay time generated by these delay cells is equal to the cycle of SPI FLASH CONTROLLER's clock nearly. This value is the result of calibration.
- Step 5** Calculate the delay time of one delay cell according to the cycle of SPI FLASH CONTROLLER's clock and the result of calibration.

#### 8.17.3.7 SPI Transfer Mode

SPI supports multiple transfer modes such as SPI Bit Mode, SPI Standard Mode, SPI Dual Mode, SPI Quad Mode, and SPI Octal Mode. Their main differences are the number of wires. Even in the same transfer mode, the detail modes will be derived based on the number of wires used to data transfer. The number of data lines used by Command-Address-Data is indicated on the subdivision pattern heading, expressed as (x-x-x). For example, Command uses one Data line, Address and data both use two data lines, identified by (1-2-2).

##### SPI Bit Mode (3-Wire/4-Wire)

For some specific scenarios, some devices such as the sensor use the SPI interfaces as the communication protocol. Generally, their data size is relatively small, and some devices support three wires, so the bit mode is added and 3-wire mode and 4-wire mode are subdivided, which includes SPI\_CS, SPI\_SCK, and 1/2 wires. The transmission length ranges from 1-32bit.

The 4-Wire Mode is selected when the Work Mode Select(bit[1:0]) is equal to 0x3 in the [SPI Bit-Aligned Transfer Configure Register](#). In SPI 4-Wire Mode, the input data and output data use the independent two data line. The MISO is used for input data, and the MOSI is used for output data.

The SPI 3-Wire Mode is only valid when the SPI controller work as Master Device, and selected when the Work Mode Select(bit[1:0]) is equal to 0x2 in the [SPI Bit-Aligned Transfer Configure Register](#). and in the 3-Wire mode, the input data and the output data use the same single data line. The following figure describe this mode.

Figure 8-113 SPI 3-Wire Mode



### SPI Standard Mode (4-Wire)

Signal Wire: CS#, SCK, IO0, and IO1.

Figure 8-114 SPI CMD with Single IO



Figure 8-115 SPI Write CMD and DATA with One Wire



Figure 8-116 SPI Write CMD and Read DATA with One Wire (No Dummy)



Figure 8-117 SPI Write CMD and Read DATA with One Wire (with Dummy)



### SPI Dual Mode

Using the dual mode allows data to be transferred to or from the device at two times the rate of standard single mode SPI devices. Data can be read at a faster speed using two data bits (MOSI and MISO) at a time. The following describe the Dual Input/Dual Output SPI (1-1-2), the Dual IO SPI (1-2-2), and the (2-2-2) SPI Mode.

- SPI Dual Input/dual Output Mode (1-1-2)

In the dual Input/dual Output SPI, the command, address, and the dummy bytes are output in the unit of a single bit in serial mode through SPI\_MOSI line. Only the data bytes are output (write) and input (read) in unit of dual bits through the SPI\_MOSI and SPI\_MISO.

**Figure 8-118 SPI Dual Input/Dual Output Mode (1-1-2)**



- SPI Dual IO Mode (1-2-2)

In the Dual IO SPI, only the command bytes are output in the unit of a single bit in serial mode through SPI\_MOSI line. The address bytes and the dummy bytes are output in the unit of dual bits through the SPI\_MOSI and SPI\_MISO. And the data bytes are output (write) and input (read) in the unit of dual bits through the SPI\_MOSI and SPI\_MISO.

**Figure 8-119 SPI Dual Input/Dual Output Mode (1-2-2)**



## SPI Quad Mode

Using the quad mode allows data to be transferred to or from the device at 4 times the rate of standard single mode SPI devices, data can be read at fast speed using four data bits (MOSI, MISO, IO2(WP#) and IO3(HOLD#)) at the same time. The following describe the Quad Input/Quad Output SPI (1-1-4), 1-4-4 mode, and 4-4-4 mode.

- Quad Input/Quad Output SPI (1-1-4)

In the Quad Input/Quad Output SPI, the command, address, and the dummy bytes are output in unit of a single bit in serial mode through SPI\_MOSI line. Only the data bytes are output (write) and input(read) in unit of quad bits through the SPI\_MOSI, SPI\_MISO, SPI\_WP# and SPI\_HOLD#.

**Figure 8-120 SPI Quad Input/Dual Output Mode (1-1-4)**



- 1-4-4 Mode

**Figure 8-121 SPI Quad Input/Dual Output Mode (1-4-4)**



- 4-4-4 Mode

Figure 8-122 SPI Quad Input/Dual Output Mode (4-4-4)



### SPI Octal Mode

The Octal SPI Mode allows data to be transferred to or from the device at eight times the rate of the standard SPI. When using the Octal SPI, there are 8 data wires.

- SPI Octal 1-1-8

Figure 8-123 SPI Octal Input/Dual Output Mode (1-1-8)



- SPI Octal 1-8-8

Figure 8-124 SPI Octal Input/Dual Output Mode (1-8-8)



- SPI Octal 8-8-8

Figure 8-125 SPI Octal Input/dual Output Mode (8-8-8)



### 8.17.3.8 SPIFC Private DMA

The private DMA adopts the chained descriptor structure. The address and size of the first descriptor are configured by registers. After getting the first descriptor, the hardware will obtain the data from the address recorded in the descriptors. When the current transfer finishes, the hardware will continue to obtain descriptors based on the address of the next descriptor given by the previous descriptor until the terminal character is found. Then, a DMA transfer ends.

Figure 8-126 Descriptor Structure Diagram



The private DMA also supports SPI parameter configuration. The SPI transfer can be configured by the parameters of the descriptors 4-7.

#### Descriptor0 Definition

| Bits | Descriptor                                                                                                                                                    |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:7 | Reserved                                                                                                                                                      |
| 6:4  | HBURST_TYPE<br>indicate hburst len<br>000: SINGLE, hburst_len = 1<br>011: INCR4, hburst_len = 4<br>101: INCR8, hburst_len = 8<br>111: INCR16, hburst_len = 16 |
| 3:2  | /                                                                                                                                                             |
| 1    | DMA_DIR                                                                                                                                                       |

| Bits | Descriptor                                              |
|------|---------------------------------------------------------|
|      | DMA Write Process or Read Process<br>0: Read<br>1:Write |
| 0    | DMA_FINISH_FLAG<br>DMA Finish Flag                      |

**Descriptor1 Definition**

| Bits  | Descriptor                                                                                                                                                                                            |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | DMA_BLK_LEN<br>DMA Block Len Mode<br>0: 8Byte<br>1: 16Byte<br>2: 32Byte<br>3: 64Byte<br>Recommended Configuration:<br>The data volume of DMA_BLK_LEN is greater than or equal to that of HBURST_TYPE. |
| 23:17 | /                                                                                                                                                                                                     |
| 16:0  | DMA_DATA_LEN<br>Indicate the data byte number of current DMA operation.                                                                                                                               |

**Descriptor2 Definition**

| Bits | Descriptor                                                                                                                        |
|------|-----------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | DMA_Buffer_SADDR<br>The real address is as below<br>The word address is needed, namely, the byte address abandons the low 2 bits. |

**Descriptor3 Definition**

| Bits | Descriptor                                                                                                                                                                                                  |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | NEXT_DESCRIPTOR_ADDR<br>These bits indicate the pointer to the physical memory where the next descriptor is present, which are word (4byte) address (The lower two bits are deleted from the byte address). |

**Descriptor4 Definition**

| Bit   | Description                |
|-------|----------------------------|
| 31:30 | /                          |
| 29    | CMD_DTR<br>CMD DTR Control |

| Bit   | Description                                                                                                                       |
|-------|-----------------------------------------------------------------------------------------------------------------------------------|
|       | 1: CMD DTR<br>0: CMD not DTR<br>CAUTION: When CMD DTR, DTR must be on and CMD2 is required.                                       |
| 28    | COMMAND_TRANS_EN<br>Set to '1' if command data need trans to device<br>SPI Controller FSM Phase Enable<br>1: Enable<br>0:Disable  |
| 27:25 | /                                                                                                                                 |
| 24    | ADDRESS_TRANS_EN<br>Set to '1' if address need trans to device<br>SPI Controller FSM Phase Enable<br>1: Enable<br>0:Disable       |
| 23:21 | /                                                                                                                                 |
| 20    | MODE_BIT_TRANS_EN<br>Set to '1' if Mode bit need trans after address<br>SPI Controller FSM Phase Enable<br>1: Enable<br>0:Disable |
| 19:17 | /                                                                                                                                 |
| 16    | DUMMY_BIT_TRANS_EN<br>Dummy Bit State Enable<br>SPI Controller FSM Phase Enable<br>1: Enable<br>0:Disable                         |
| 15:13 | /                                                                                                                                 |
| 12    | TX_DATA_EN<br>Set to '1' if Data Need Trans<br>SPI Controller FSM Phase Enable<br>1: Enable<br>0:Disable                          |
| 11:9  | /                                                                                                                                 |
| 8     | RX_DATA_EN<br>Set to '1' if Data Need Receive<br>SPI Controller FSM Phase Enable<br>1: Enable<br>0:Disable                        |
| 7:0   | /                                                                                                                                 |

#### Descriptor5 Definition

| Bit | Description |
|-----|-------------|
|-----|-------------|

| Bit  | Description                                      |
|------|--------------------------------------------------|
| 31:0 | ADDR_OPCODE<br>Address Content Trans Through SPI |

**Descriptor6 Definition**

This register should be setup while the controller is idle.

| Bit   | Description                                                                                                                                                                                                                                                                    |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | CMD_OPCODE<br>Command Content Trans Through SPI                                                                                                                                                                                                                                |
| 23:16 | MODE_OPCODE<br>Mode Content Trans Through SPI                                                                                                                                                                                                                                  |
| 15:8  | CMD_OPCODE2<br>Command2 Content Trans Through SPI                                                                                                                                                                                                                              |
| 7:6   | CMD_TRANS_TYPE<br>Command Transfer Type<br>00: Command can be Shifted to the device on DQ0<br>01: Command can be Shifted to the device on DQ0 and DQ1<br>10: Command can be Shifted to the device on DQ0- DQ3<br>11 : Command can be Shifted to the device on DQ0-DQ7          |
| 5:4   | ADDR_TRANS_TYPE<br>Address Transfer Type<br>00: Address can be Shifted to the device on DQ0<br>01: Address can be Shifted to the device on DQ0 and DQ1<br>10: Address can be Shifted to the device on DQ0- DQ3<br>11: Address can be Shifted to the device on DQ0-DQ7          |
| 3:2   | MODE_BIT_TRANS_TYPE<br>Mode Bit Transfer Type<br>00: Mode Bit can be Shifted to the device on DQ0<br>01: Mode Bit can be Shifted to the device on DQ0 and DQ1<br>10: Mode Bit can be Shifted to the device on DQ0- DQ3<br>11: Mode Bit can be Shifted to the device on DQ0-DQ7 |
| 1:0   | DATA_TRANS_TYPE<br>Data Transfer Type<br>00: Opcode can be Shifted to the device on DQ0 only<br>01: Opcode can be Shifted to the device on DQ0 and DQ1 only<br>10: Opcode can be Shifted to the device on DQ0- DQ3<br>11: Opcode can be Shifted to the device on DQ0-DQ7       |

**Descriptor7 Definition**

| Bit   | Description        |
|-------|--------------------|
| 31    | DATA_TRANS_NUM[16] |
| 30:29 |                    |

| Bit   | Description                                                                                                                                                                                                                                                                                                                                               |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 28    | SPI_NORMAL_EN<br>if dma config spi, this bit start SPI FSM.                                                                                                                                                                                                                                                                                               |
| 27:25 | /                                                                                                                                                                                                                                                                                                                                                         |
| 24    | ADDR_SIZE_MODE<br>Address Size Mode<br>0: Address Size 24bit.<br>1: Address Size 32bit.                                                                                                                                                                                                                                                                   |
| 23:16 | DUMMY_TRANS_NUM<br>Number of Dummy Cycles<br>A value of 0 = 1 Cycle<br>A value of 1 = 1 Cycle<br>...<br>A value of N = N Cycle                                                                                                                                                                                                                            |
| 15:0  | DATA_TRANS_NUM<br>Num of Data Trans Through SPI(Byte)<br>0: Non-Write.<br>1: Write 1 Byte.<br>2: Write 2 Bytes.<br>3: Write 3 Bytes.<br>.....<br>65535: Write 65535 Bytes.<br><b>Note:</b> These Bits Indicate number of data bytes in a CHIP SELECT period.<br><b>Notice the difference between DATA_TRANS_NUM here and DMA_DATA_LEN in Descriptor1.</b> |

## 8.17.4 Programming Guidelines

### 8.17.4.1 DMA Transfer

The software operation of the SPI DMA transfer is divided into 5 steps. 5 steps are described in detail in the following sections.

**Step 1** System Setup

**Step 2** SPI Initialization

**Step 3** Channel Setup

**Step 4** DMA Setup

**Step 5** Enable SPI

**Figure 8-127 SPI Programming flow**

#### 8.17.4.2 System Setup

**Step 1** Configure SPI Pin

Programming the GPIO.

**Step 2** Configure SPI Clock and Reset in CCU

Configure SPI ref clock, AHB Clock, De-assert SPI ref Reset, and AHB reset in Clock Controller Unit (CCU).

**Step 3** Configure SPI Internal Working Clock

a) Configure clock source ([SPI\\_TIMING\\_CFG](#)[0x000C])

➤ STR Mode

Write 0 to the CLK\_SPI\_SRC\_SEL bit (bit [24]), the CLK\_SCK\_SRC\_SEL bit (bit [25]) bit, and the CLK\_SCKOUT\_SRC\_SEL bit (bit [26]) bit.

➤ DTR Mode

Write 0 to the CLK\_SPI\_SRC\_SEL bit (bit [24]) and the CLK\_SCK\_SRC\_SEL bit (bit [25]) bit.

Write 1 to the CLK\_SCKOUT\_SRC\_SEL bit (bit [26]) bit.



When the value of the CLK\_SCKOUT\_SRC\_SEL bit (bit [26]) bit is 1, the real output clock frequency of SPIFC-CLK signal is the SPIFC clock frequency divided by 2.

b) Generate the sckr of SPI data receiving

➤ Configure SCKR delay mode ([SPI\\_TIMING\\_CFG](#)[0x000C]). Refer to the section SPI Run Clock and Sample Mode for more details.

SCKR\_DLY\_MODE\_SEL (bit [20]): Select delay mode. Writing 0 is the digital delay, and writing 1 is the digital and analog delay.

- Configure the digital delay of SCKR  
[SPI\\_TIMING\\_CFG](#)[0x000C], DIGITAL\_SCKR\_DELAY\_CFG (bit[18:16]): digital delay volume. (step length: 0.5 clock)
- Configure the analog delay of SCKR  
[SPI\\_TIMING\\_CFG](#)[0x000C], ANALOG\_SAMP\_DL\_SW\_VALUE (bit[5:0])
- c) Generate SPI output clock
  - Select SPI working mode (SPI\_MODE). Refer to the section SPI Flash Controller Clock Mode for more details.
  - Configure [SPI\\_GLOBAL\\_CTRL](#)[0x0004]:
    - SPI\_CPOL (bit [5]): Clock Polarity
    - SPI\_CPHA (bit [4]): Clock Phase
  - DTR switch ([SPI\\_GLOBAL\\_CTRL](#)[0x0004])  
DTR\_EN (bit [16]): It is closed by default.

#### Step 4 Configure SPI Interrupt

Configure the SPI\_INT\_EN (0x0014[31:0]) as 0.

### 8.17.4.3 SPI Initialization

After the system setup, the registers of SPI can be setup. At first, the SPI needs to be initialized.

#### Step 1 Disable the [SPI\\_GLOBAL\\_CTRL](#).

SPI\_NMODE\_EN (bit [2]): Write 0.

#### Step 2 Reset TX/RX FIFO ([SPI\\_GLOBAL\\_CTRL\\_ADD](#)[0x0008])

Reset the CDC-BUF/FIFO of TX channel: Write 1 to CDC\_WF\_SRST to reset the WR\_BUFF and WR\_FIFO in SPI\_WR\_BUF\_CTRL and the SWF in SPI\_TX\_INTERFACE.

Reset the CDC-BUF/FIFO of RX channel: Write 1 to CDC\_RF\_SRST.

#### Step 3 Water Lever

Configure the water level of FIFO.

[SPI\\_CDC\\_FIFO\\_TRIG\\_LEVEL](#)[0x004C]

### 8.17.4.4 Channel Setup

#### Select SPI Channel Parameter Resource

- SPI channel parameter resources:

- CPU is configured by AHB.
- The private DMA fetches descriptors and parses the descriptors 4-7.
- Configure SPI channel parameter sources: [SPI\\_GLOBAL\\_CTRL](#)[0x0004] and [SPI\\_CFG\\_MODE](#)(bit[0])
  - 0: Source from CPU
  - 1: Source from DMA descriptor



#### NOTE

If the parameters source from CPU, configure in reference to all the guidelines in the section Channel Setup. If the parameters source from DMA, configure in reference to the first two guidelines in the section 8.17.4.4 Channel Setup.

### SPI Interface Configuration—Public Configuration

#### Step 1 CS Delay Configuration: [SPI\\_CS\\_DELAY](#)[0x001C]

- CSDA (bit [23:16]): The intervals of two adjacent CS enable. The minimum interval is 1sclk. The actual value is CSDA+1.
- CSEOT (bit [15:8]): After the SCLK\_OUT is invalid, the CS signal will be de-asserted after CSEOT SCLK. The minimum interval is 1sclk. The actual value is CSEOT+1.
- CSSOT (bit [7:0]): After the SCLK\_OUT is valid, the CS signal will be asserted after CSSOT SCLK. The minimum interval is 1sclk. The actual value is CSSOT+1.

#### Step 2 Activate SPI Trans Phase ([SPI\\_TRANS\\_PHA\\_CFG](#)[0x0020])

In a transmission of the SPI interface, the transferring content of I/O wire is as follows. Enable the corresponding Trans Phase based on the content to be transferred.

Figure 8-128 SPI Transfer Phase Flow Diagram



- COMMAND\_TRANS\_EN (bit [28]): Command (Instruct) Transfer Enable
- ADDRESS\_TRANS\_EN (bit [24]): Address Transfer Enable
- MODE\_BIT\_TRANS\_EN (bit [20]): Mode Transfer Enable
- DUMMY\_BIT\_TRANS\_EN (bit [16]): Dummy Transfer Enable
- TX\_DATA\_EN (bit [12]): Enable TX data transfer.
- RX\_DATA\_EN (bit [8]): Enable RX data transfer.



## NOTE

RX\_DATA\_EN and TX\_DATA\_EN cannot be activated at the same time.

**Step 3** Configure the number of I/O used by TransPhase. ([SPI\\_TRANS\\_CFG2](#)[0x0028])

- CMD\_TRANS\_TYPE (bit [13:12])
- ADDR\_TRANS\_TYPE (bit [9:8])
- MODE\_BIT\_TRANS\_TYPE (bit [5:4])
- DATA\_BIT\_TRANS\_TYPE (bit [1:0])

**Step 4** Configure the transferring number of TransPhase ([SPI\\_TRANS\\_NUM](#)[0x002C])

### SPI Interface Configuration—Normal Mode

Configure the contents of all TransPhase

- ADDR: SPI\_TRANS\_CFG1[0x0024], ADDR\_OPCODE (bit [31:0])
- CMD: [SPI\\_TRANS\\_CFG2](#)[0x0028], CMD\_OPCODE (bit[31:24])
- MODE: [SPI\\_TRANS\\_CFG2](#)[0x0028], CMD\_OPCODE (bit[23:16])

### SPI Interface Configuration—BIT Mode

Refer to the functions of SPI Bit Mode (3-Wire/4-Wire).

#### 8.17.4.5 DMA Setup

##### DMA Configuration Registers

**Step 1** Configure the descriptor size and starting address of the first descriptor.

- [SPI\\_DMA\\_CTRL](#)[0x0040]: DMA\_DESCRIPTOR\_LEN (bit[11:4])
- [SPI\\_DESCRIPTOR\\_SADDR](#)[0x0044]

**Step 2** Initiate DMA

[SPI\\_DMA\\_CTRL](#)[0x0040], CFG\_DMA\_START (bit[0])

##### DMA Configuration

**Step 1** In the DMA register, configure the size and the starting address of storage location for the first descriptor.

**Step 2** Configure the first DMA descriptor and store the corresponding address in the step 1.

- Descriptor0
  - AHB Master Burst Configuration

HBURST\_TYPE (bit [6:4]): Support SINGLE/INCR4/INCR8/INCR16 mode.

- DMA Handling Direction Configuration

DMA\_DIR (bit [1]): Read by DMA, or Write by DMA.

- DMA Finish Flag

DMA\_FINISH\_FLAG (bit [0]): Currently the memory space allocated by the CPU to DMA may be a part of the total data volume to be transferred. For instance, the 256 Byte memory space is allocated to transfer 1 MB data. In this situation, a DMA descriptor points to the allocated 256 Byte data location and the next descriptor to fetch data. When the data of the last descriptor is fetched by DMA, the stop bit should be pulled up to terminate a DMA handling.

➤ Descriptor1

- DMA\_BLK\_LEN ([31:16])

DMA BLK length. It indicates the size of each DMA packet, with multiples of 8 Byte aligned to achieve the optimized rate when accessing storage.

- DMA\_DATA\_LEN (bit [15:0])

It indicates the data volume indicated by the current descriptor of DMA

➤ Descriptor2

It indicates the data storage location of current descriptor.

➤ Descriptor3

It indicates the storage location of the next descriptor.

➤ Descriptor4-7

The SPI configuration parameters. When setting parameters with DMA for SPI, the content of descriptors is configured to SPI.

#### 8.17.4.6 Enable SPI

##### Normal Mode

SPI\_GLOBAL\_CTRL[0x0004], SPI\_NMODE\_EN (bit[2])

Write 1 to the SPI\_NMODE\_EN, then it will be auto pulled down.

#### 8.17.4.7 CPU Transfer

The software operation of CPU transfer is almost the same as DMA transfer. There are still two main differences. One difference is that when CPU transfer, channel parameter cannot come from DMA descriptors. SPI\_GLOBAL\_CTRL[0x0004], SPI\_CFG\_MODE(bit[0]) must be set 0. All parameters should come from REGISTER FILE.

SPI\_GLOBAL\_CTRL[0x0004], SPI\_CPU\_MODE\_EN(bit[20]) is used to start CPU transfer (Different from descriptor and SPI\_GLOBAL\_CTRL[0x0004], SPI\_NMODE\_EN(bit[2])).

Another difference is that when reading data from Register [0x0210], it is recommended to read [SPI\\_CDC\\_FIFO\\_STA](#)[0x0050], RF\_CNT([bit5-0]), especially when total read number is not integer multiple of trigger level. When writing data to Register [0x0220], it is always ready as long as trigger level is not reached.



#### NOTE

Register [0x0040] and [0x0044] are not used in CPU transfer.

#### 8.17.4.8 Status Reading

The software operation of STATUS READING is almost the same as CPU transfer. CMD\_TRANS\_EN and RX\_DATA\_EN must be set high because RX data path is used for status reading. MODE\_BIT\_TRANS\_EN and DUMMY\_BIT\_TRANS\_EN should be set accordingly. But STATUS OPCODE will not go through READ\_FIFO and READ\_BUFFER. Meanwhile, I/O Pins used should be set accordingly. [SPI\\_STATUS\\_READ](#)[0x0068] and [SPI\\_STATUS\\_READ\\_2](#)[0x006C] are used for STATUS READING. And to avoid endless reading and dead lock, CPU should tell the maximum reading times. Then, to start STATUS READING, SPI\_READ\_STATUS\_MODE\_EN should be set. In this mode, DATA\_TRANS\_NUM (002C, [15:0]) is suggested to be 1 and DTR\_EN [0x0004, bit 16] is suggested to be 0.

#### 8.17.5 Register List

| Module Name | Base Address |
|-------------|--------------|
| SPIFC       | 0x047F 0000  |

| Register Name           | Offset | Description                               |
|-------------------------|--------|-------------------------------------------|
| SPI_GLOBAL_CTRL         | 0x0004 | SPI Global Control Register               |
| SPI_GLOBAL_CTRL_ADD     | 0x0008 | SPI Global Control Additional Register    |
| SPI_TIMING_CFG          | 0x000C | SPI Timing Configure Register             |
| SPI_TIMING_DLY_STA      | 0x0010 | SPI Timing Delay State Register           |
| SPI_INT_EN              | 0x0014 | SPI Interrupt Enable Register             |
| SPI_INT_STA             | 0x0018 | SPI Interrupt Status Register             |
| SPI_CS_DELAY            | 0x001C | SPI Chipselect Delay Register             |
| SPI_TRANS_PHA_CFG       | 0x0020 | SPI Trans Phase Configure Register        |
| SPI_TRANS_CFG1          | 0x0024 | SPI Trans Configure1 Register             |
| SPI_TRANS_CFG2          | 0x0028 | SPI Trans Configure2 Register             |
| SPI_TRANS_NUM           | 0x002C | SPI Trans Number Register                 |
| SPI_DMA_CTRL            | 0x0040 | SPI DMA Control Register                  |
| SPI_DESCRIPTOR_SADDR    | 0x0044 | SPI DMA Descriptor Start Address Register |
| SPI_CDC_FIFO_TRIG_LEVEL | 0x004C | SPI CDC FIFO Trigger Level Register       |
| SPI_CDC_FIFO_STA        | 0x0050 | SPI CDC FIFO Status Register              |

| Register Name    | Offset | Description                                  |
|------------------|--------|----------------------------------------------|
| SPI_BATC         | 0x0054 | SPI Bit-Aligned Transfer Configure Register  |
| SPI_BA_CCR       | 0x0058 | SPI Bit-Aligned CLOCK Configuration Register |
| SPI_TBR          | 0x005C | SPI TX Bit Register                          |
| SPI_RBR          | 0x0060 | SPI RX Bit Register                          |
| SPI_STATUS       | 0x0064 | SPI Status Register                          |
| SPI_STATUS_READ  | 0x0068 | SPI READ Status Register                     |
| SPI_STATUS_READ2 | 0x006C | SPI READ Status Register_2                   |
| SPI_RX_DATA      | 0x0210 | SPI RX Data Register                         |
| SPI_TX_DATA      | 0x0220 | SPI TX Data Register                         |

## 8.17.6 Register Description

### 8.17.6.1 0x0004 SPI Global Control Register (Default Value: 0x0000\_0100)

| Offset: 0x0004 |            |             | Register Name: SPI_GLOBAL_CTRL                                                                                                                                                                                                                   |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                      |
| 31:23          | /          | /           | /                                                                                                                                                                                                                                                |
| 22             | R/W        | 0x0         | START_MODE<br>0: old start mode<br>1: new start mode                                                                                                                                                                                             |
| 21             | R/WAC      | 0x0         | SPI_READ_STATUS_MODE_EN<br>SPI READ STATUS Mode Enable<br>0: Disable<br>1: Enable<br>This bit is not used for data transfer. It is used for status confirm. And when this operation ends, the last returned byte value is sent to 0x0064[31:24]. |
| 20             | R/WAC      | 0x0         | SPI_CPU_MODE_EN<br>SPI CPU Mode Enable<br>0: Disable<br>1: Enable<br>CPU transfer mode.                                                                                                                                                          |
| 19             | R/W        | 0x0         | SPI_CLK_OUTPUT<br>0: Disable<br>1: Enable<br>when the SPI_CLK_OUTPUT is enabled, the SPI FLASH CONTROLLER will convey the sclk from CCU to the spi_sck_out pin. This bit cannot be enabled in the process of data transmission to avoid anomaly. |
| 18             | R/W        | 0x0         | SPI_TX_CFG_FBS<br>Transmit Interface First Transmit Bit Select.<br>0: MSB First                                                                                                                                                                  |

| Offset: 0x0004 |            |             | Register Name: SPI_GLOBAL_CTRL                                                                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                             |
|                |            |             | 1: LSB First                                                                                                                                                                                                                                                                                                                                            |
| 17             | R/W        | 0x0         | SPI_RX_CFG_FBS<br>Receive Interface First Transmit Bit Select.<br>0: MSB First<br>1: LSB First                                                                                                                                                                                                                                                          |
| 16             | R/W        | 0x0         | DTR_EN<br>Double Trans Rate Enable<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                                                           |
| 15             | R/W        | 0x0         | SPI_WP_EN<br>0: Disable<br>1: Enable<br>In Standard SPI or Dual SPI, SPI PIN Write Protect Function can be Open<br>In the open status, SPI_WP_IO2_OUT is enabled. The exact polarity is decided by the configuration of SPI_WP_POL.<br>In the closed status, SPI_WP_IO2_OUT is controlled by hardware. The exact polarity is decided by the controller. |
| 14             | R/W        | 0x0         | SPI_WP_POL<br>SPI PIN Write Protect Polar<br>0: Active high polarity (0 = Idle)<br>1: Active low polarity (1 = Idle)                                                                                                                                                                                                                                    |
| 13             | R/W        | 0x0         | SPI_HOLD_EN<br>0: Disable<br>1: Enable<br>In Standard SPI or Dual SPI, SPI PIN HOLD Function can be Open<br>In the open status, SPI_HOLD_IO3_OUT is enabled. The exact polarity is decided by the configuration of SPI_HOLD_POL.<br>In the closed status, SPI_HOLD_IO3_OUT is controlled by hardware. The exact polarity is decided by the controller.  |
| 12             | R/W        | 0x0         | SPI_HOLD_POL<br>SPI PIN HOLD Polar<br>0: Active high polarity (0 = Idle)<br>1: Active low polarity (1 = Idle)                                                                                                                                                                                                                                           |
| 11             | /          | /           | /                                                                                                                                                                                                                                                                                                                                                       |
| 10             | R/W        | 0x0         | DQS_RX_EN                                                                                                                                                                                                                                                                                                                                               |

| Offset: 0x0004 |            |             | Register Name: SPI_GLOBAL_CTRL                                                                                                                                                                                        |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                           |
|                |            |             | Receive DQS Signal Enable<br>0: Disable<br>1: Enable                                                                                                                                                                  |
| 9              | R/W        | 0x0         | DUMMY_BIT_POL<br>Dummy Bit Trans Value<br>0: Dummy bit Trans 0<br>1: Dummy bit Trans 1                                                                                                                                |
| 8              | R/W        | 0x1         | SPI_CS_POL<br>SPI Chip Select Signal Polarity Control<br>0: Active high polarity (0 = Idle)<br>1: Active low polarity (1 = Idle)                                                                                      |
| 7:6            | R/W        | 0x0         | SPI_CS_SEL<br>SPI Chip Select<br>Select one of four external SPI Master/Slave Devices<br>00: SPI_SS0 will be asserted<br>01: SPI_SS1 will be asserted<br>10: SPI_SS2 will be asserted<br>11: SPI_SS3 will be asserted |
| 5              | R/W        | 0x0         | SPI_CPOL<br>SPI Clock Polarity Control<br>0: Active High Polarity.<br>1: Active Low Polarity.                                                                                                                         |
| 4              | R/W        | 0x0         | SPI_CPHA<br>SPI Clock/Data Phase Control<br>0: Phase 0(Leading Edge for Sample Data)<br>1: Phase 1(Leading Edge For Setup Data)                                                                                       |
| 3              | /          | /           | /                                                                                                                                                                                                                     |
| 2              | R/WAC      | 0x0         | SPI_NMODE_EN<br>SPI Normal Mode Enable<br>0: Disable<br>1: Enable<br>DMA transfer mode.                                                                                                                               |
| 1              | /          | /           | /                                                                                                                                                                                                                     |
| 0              | R/W        | 0x0         | SPI_CFG_MODE<br>SPI Parameter Config Source in normal(DMA) mode.<br>Set to 0 When CPU Transfer.<br>0: From REGISTER<br>1: From DMA Descriptor                                                                         |

### 8.17.6.2 0x0008 SPI Global Control Additional Register (Default Value: 0x0000\_0000)

| Offset: 0x0008 |            |             | Register Name: SPI_GLOBAL_CTRL_ADD                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                            |
| 31:5           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 4              | R/WAC      | 0x0         | SPI_FLASH_DMA_END<br>Terminate the DMA Chain after the present BLK is done.<br><br>After the DMA chain terminates, set 1 to this bit to stop DMA transmission after the DMA module finishes the BLK whether the current chain completes or the finish_flag is set to 1.<br><br>DMA-END and SPI_SRST should be used together:<br>Enable the DMA-END first, and then enable the SPI_FLASH_SRST after DMA-END is cleared. |
| 3              | R/WAC      | 0x0         | SPI_FLASH_SRST<br>Reset All the Logic in SPI Flash (DMA chain is not included)                                                                                                                                                                                                                                                                                                                                         |
| 2              | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 1              | R/WAC      | 0x0         | CDC_WF_SRST<br>Transfer FIFO Software Reset, In SPI_WR_BUF_CTRL Module<br>0: Auto Clear to 0.<br>1: Reset Transfer FIFO.<br><br>Writing 1 to this bit will reset the control portion of the transfer FIFO, and auto clear to 0 when completing reset operation. Writing 0 to this bit has no effect.                                                                                                                   |
| 0              | R/WAC      | 0x0         | CDC_RF_SRST<br>Receiver FIFO Software Reset, In SPI_RD_BUF_CTRL Module<br>0: Auto Clear to 0.<br>1: Reset Receiver FIFO.<br><br>Write '1' to this bit will reset the control portion of the receiver FIFO, and auto clear to '0' when completing reset operation, write '0' to this bit has no effect.                                                                                                                 |

### 8.17.6.3 0x000C SPI Timing Configure Register (Default Value: 0x0000\_0000)

| Offset: 0x000C |            |             | Register Name: SPI_TIMING_CFG               |
|----------------|------------|-------------|---------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                 |
| 31:27          | /          | /           | /                                           |
| 26             | R/W        | 0x0         | CLK_SCKOUT_SRC_SEL<br>SPI Output Clk Select |

| Offset: 0x000C |            |             | Register Name: SPI_TIMING_CFG                                                                                                                                                                                                                       |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                         |
|                |            |             | Select the rate of SPI output clock (SCK_OUT).<br>0: Original Clock<br>1: Two-frequency Clock                                                                                                                                                       |
| 25             | R/W        | 0x0         | CLK_SCK_SRC_SEL<br>SPI Interface Clock Select<br>0: Original Clock<br>1: Two-frequency Clock                                                                                                                                                        |
| 24             | R/W        | 0x0         | CLK_SPI_SRC_SEL<br>SPI Inter Process Clock Select<br>0: Original Clock<br>1: Two-frequency                                                                                                                                                          |
| 23:22          | /          | /           | /                                                                                                                                                                                                                                                   |
| 21             | R/W        | 0x0         | SCKT_DELAY_MODE_SEL<br>SCKT Delay Mode Select<br>0: Select the SCKT without delay<br>1: Select the SCKT after the analog delay chain adjustment                                                                                                     |
| 20             | R/W        | 0x0         | SCKR_DELAY_MODE_SEL<br>SCKR Delay Mode Select<br>0: digital delay<br>1: digital delay + analog delay                                                                                                                                                |
| 19             | /          | /           | /                                                                                                                                                                                                                                                   |
| 18:16          | R/W        | 0x0         | DIGITAL_SCKR_DELAY_CFG<br>Digital SCKR Delay Value Config, Step 0.5 spi_clk<br>000: delay 0 clk<br>001: delay 0.5 clk<br>010: delay 1 clk<br>011: delay 1.5 clk<br>100: delay 2 clk<br>101: delay 2.5 clk<br>110: delay 3 clk<br>111: delay 3.5 clk |
| 15             | R/W        | 0x0         | ANALOG_SAMP_DL_CAL_START_TX<br>Sample Delay Calibration Start<br>When set, start sample delay chain calibration.                                                                                                                                    |
| 14             | R/W        | 0x0         | ANALOG_SAMP_DL_SW_EN_TX<br>Sample Delay Software Enable<br>When set, enable sample delay specified at SAMP_DL_SW                                                                                                                                    |
| 13:8           | R/W        | 0x0         | ANALOG_SAMP_DL_SW_VALUE_TX<br>Sample Delay Software Value                                                                                                                                                                                           |

| Offset: 0x000C |            |             | Register Name: SPI_TIMING_CFG                                                                                                                                                                                                                              |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                |
|                |            |             | The relative delay between clock line and command line, data lines.<br>It can be determined according to the value of SAMP_DL, the cycle of card clock and device's input timing requirement.                                                              |
| 7              | R/W        | 0x0         | ANALOG_SAMP_DL_CAL_START_RX<br>Sample Delay Calibration Start<br>When set, start sample delay chain calibration.                                                                                                                                           |
| 6              | R/W        | 0x0         | ANALOG_SAMP_DL_SW_EN_RX<br>Sample Delay Software Enable<br>When set, enable sample delay specified at SAMP_DL_SW                                                                                                                                           |
| 5:0            | R/W        | 0x0         | ANALOG_SAMP_DL_SW_VALUE_RX<br>Sample Delay Software Value<br>The relative delay between clock line and command line, data lines.<br>It can be determined according to the value of SAMP_DL, the cycle of card clock and device's input timing requirement. |

#### 8.17.6.4 0x0010 SPI Timing Delay State Register (Default Value: 0x0000\_2020)

| Offset: 0x0010 |            |             | Register Name: SPI_TIMING_DLY_STA                                                                                                                                                                                                                                                                                                                                |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                      |
| 31:16          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                |
| 15             | R          | 0x0         | ANALOG_SAMP_DL_CAL_DONE_TX<br>Sample Delay Calibration Done<br>When set, it means that sample delay chain calibration is done and the result of calibration is shown in SAMP_DL.                                                                                                                                                                                 |
| 14             | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                |
| 13:8           | R          | 0x20        | ANALOG_SAMP_DL_TX<br>Sample Delay Value<br>It indicates the number of delay cells corresponding to current card clock. The delay time generated by these delay cells is equal to the cycle of card clock nearly.<br>Generally, it is necessary to do drive delay calibration when card clock is changed.<br>This bit is valid only when SAMP_DL_CAL_DONE is set. |

| Offset: 0x0010 |            |             | Register Name: SPI_TIMING_DLY_STA                                                                                                                                                                                                                                                                                                                                |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                      |
| 7              | R          | 0x0         | ANALOG_SAMP_DL_CAL_DONE_RX<br>Sample Delay Calibration Done<br>When set, it means that sample delay chain calibration is done and the result of calibration is shown in SAMP_DL.                                                                                                                                                                                 |
| 6              | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                |
| 5:0            | R          | 0x20        | ANALOG_SAMP_DL_RX<br>Sample Delay Value<br>It indicates the number of delay cells corresponding to current card clock. The delay time generated by these delay cells is equal to the cycle of card clock nearly.<br>Generally, it is necessary to do drive delay calibration when card clock is changed.<br>This bit is valid only when SAMP_DL_CAL_DONE is set. |

#### 8.17.6.5 0x0014 SPI Interrupt Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x0014 |            |             | Name: SPI_INT_EN                                                                                 |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                      |
| 31:29          | /          | /           | /                                                                                                |
| 28             | R/W        | 0x0         | READ_STATUS_DONE_INT_EN<br>0: Disable.<br>1: Enable.                                             |
| 27             | R/W        | 0x0         | READ_STATUS_TIME_OUT_INT_EN<br>0: Disable.<br>1: Enable.                                         |
| 26             | R/W        | 0x0         | SPI_TRANS_DONE_INT_EN<br>SPI Transmit Finish Interrupt Enable<br>0: Disable.<br>1: Enable.       |
| 25             | /          | /           | /                                                                                                |
| 24             | R/W        | 0x0         | DMA_TRANS_DONE_INT_EN<br>DMA Chain Transmit Finish Interrupt Enable<br>0: Disable.<br>1: Enable. |
| 23             | R/W        | 0x0         | DQS_RF_ODD_UDF_INT_EN<br>DQS Receive FIFO Underflow Interrupt Enable<br>0: Disable.              |

| Offset: 0x0014 |            |             | Name: SPI_INT_EN                                                                                   |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                        |
|                |            |             | 1: Enable.<br>0: Disable.                                                                          |
| 22             | R/W        | 0x0         | DQS_RF_ODD_OVF_INT_EN<br>DQS Receive FIFO Overflow Interrupt Enable<br>0: Disable.<br>1: Enable.   |
| 21             | R/W        | 0x0         | DQS_RF_EVEN_UDF_INT_EN<br>DQS Receive FIFO Underflow Interrupt Enable<br>0: Disable.<br>1: Enable. |
| 20             | R/W        | 0x0         | DQS_RF_EVEN_OVF_INT_EN<br>DQS Receive FIFO Overflow Interrupt Enable<br>0: Disable.<br>1: Enable.  |
| 19:12          | /          | /           | /                                                                                                  |
| 11             | R/W        | 0x0         | WF_UDF_INT_EN<br>Write FIFO Underflow Interrupt Enable<br>0: Disable.<br>1: Enable.                |
| 10             | R/W        | 0x0         | WF_OVF_INT_EN<br>Write FIFO Overflow Interrupt Enable<br>0: Disable.<br>1: Enable.                 |
| 9              | R/W        | 0x0         | RF_UDF_INT_EN<br>Read FIFO Underflow Interrupt Enable<br>0: Disable.<br>1: Enable.                 |
| 8              | R/W        | 0x0         | RF_OVF_INT_EN<br>Read FIFO Overflow Interrupt Enable<br>0: Disable.<br>1: Enable.                  |
| 7:5            | /          | /           | /                                                                                                  |
| 4              | R/W        | 0x0         | WF_RDY_INT_EN<br>Write FIFO Ready Request Interrupt Enable<br>0: Disable.<br>1: Enable.            |
| 3:1            | /          | /           | /                                                                                                  |
| 0              | R/W        | 0x0         | RF_RDY_INT_EN<br>Read FIFO Ready Request Interrupt Enable<br>0: Disable.<br>1: Enable.             |

## 8.17.6.6 0x0018 SPI Interrupt Status Register (Default Value: 0x0000\_0010)

| Offset: 0x0018 |            |             | Name: SPI_INT_STA                                                                                                                                                                      |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                            |
| 31:29          | /          | /           | /                                                                                                                                                                                      |
| 28             | R/W1C      | 0x0         | READ_STATUS_DONE_INT<br>READ_STATUS MODE Done Interrupt. When set, this bit indicates that at least one wanted bit has got expected value.                                             |
| 27             | R/W1C      | 0x0         | READ_STATUS_TIME_OUT_INT<br>READ_STATUS MODE TIME OUT Interrupt. When set, this bit indicates that READ_STATUS MODE ends and in the written period, no wanted bit gets expected value. |
| 26             | R/W1C      | 0x0         | SPI_TRANS_DONE_INT<br>SPI Transmit Finish Interrupt                                                                                                                                    |
| 25             | /          | /           | /                                                                                                                                                                                      |
| 24             | R/W1C      | 0x0         | DMA_TRANS_DONE_INT<br>DMA Chain Transmit Finish Interrupt<br>Note: When set, this bit indicates that Write FIFO has underflow. Writing "1" to this bit clears it.                      |
| 23             | R/W1C      | 0x0         | DQS_RF_ODD_UDF_INT<br>DQS Receive FIFO underflow Interrupt Flag<br>Note: When set, this bit indicates that Write FIFO has underflow. Writing "1" to this bit clears it.                |
| 22             | R/W1C      | 0x0         | DQS_RF_ODD_OVF_INT<br>DQS Receive FIFO Overflow Interrupt Flag<br>Note: When set, this bit indicates that Write FIFO has overflowed. Writing "1" to this bit clears it.                |
| 21             | R/W1C      | 0x0         | DQS_RF_EVEN_UDF_INT<br>DQS Receive FIFO Underflow Interrupt Flag<br>Note: When set, this bit indicates that Read FIFO has underflow. Writing "1" to this bit clears it.                |
| 20             | R/W1C      | 0x0         | DQS_RF_EVEN_OVF_INT<br>DQS Receive FIFO Overflow Interrupt Flag<br>Note: When set, this bit indicates that Read FIFO has overflowed. Writing "1" to this bit clears it.                |
| 19:12          | /          | /           | /                                                                                                                                                                                      |
| 11             | R/W1C      | 0x0         | WF_UDF_INT<br>Write FIFO underflow Interrupt Flag<br>Note: When set, this bit indicates that Write FIFO has underflow. Writing "1" to this bit clears it.                              |
| 10             | R/W1C      | 0x0         | WF_OVF_INT                                                                                                                                                                             |

| Offset: 0x0018 |            |             | Name: SPI_INT_STA                                                                                                                                                                                                                                                                                                                                                                        |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                              |
|                |            |             | Write FIFO Overflow Interrupt Flag<br>Note: When set, this bit indicates that Write FIFO has overflowed. Writing "1" to this bit clears it.                                                                                                                                                                                                                                              |
| 9              | R/W1C      | 0x0         | RF_UDF_INT<br>Read FIFO Underflow Interrupt Flag<br>Note: When set, this bit indicates that Read FIFO has underflow. Writing "1" to this bit clears it.                                                                                                                                                                                                                                  |
| 8              | R/W1C      | 0x0         | RF_OVF_INT<br>Read FIFO Overflow Interrupt Flag<br>Note: When set, this bit indicates that Read FIFO has overflowed. Writing "1" to this bit clears it.                                                                                                                                                                                                                                  |
| 7:5            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                        |
| 4              | R/W1C      | 0x1         | WF_RDY_INT<br>Write FIFO Ready Request Interrupt Flag<br>0: WF_WL > WF_EMPTY_TRIG_LEVEL.<br>1: WF_WL <= WF_EMPTY_TRIG_LEVEL.<br>This bit is set any time if WF_WL <= WF_EMPTY_TRIG_LEVEL. Writing "1" to this bit clears it.                                                                                                                                                             |
| 3:1            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                        |
| 0              | R/W1C      | 0x0         | RF_RDY_INT<br>Read FIFO Ready Request Interrupt Flag<br>0: RF_WL < RX_EMPTY_TRIG_LEVEL and rest total RX data byte number is larger than RX_EMPTY_TRIG_LEVEL.<br>1: RF_WL >= RX_EMPTY_TRIG_LEVEL, or rest total RX data byte number is smaller than RX_EMPTY_TRIG_LEVEL meanwhile RF_WL >= 1.<br>This bit is set any time if condition is reached.<br>Writing "1" to this bit clears it. |

#### 8.17.6.7 0x001C SPI Chipselect Delay Register (Default Value: 0x0000\_0606)

| Offset: 0x001C |            |             | Register Name: SPI_CS_DELAY                                                                                                                                                                                    |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                    |
| 31:24          | R/W        | 0x0         | DBG_SEL<br>0: The high 8 bits of debug signal are io*_oen, and the low 8 bits are 0.<br>1: The high 8 bits are WF_CNT, and the low 8 bits are RF_CNT.<br>2: The high 8 bits are WB_CNT, and the low 8 bits are |

| Offset: 0x001C |            |             | Register Name: SPI_CS_DELAY                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                |            |             | <p>RB_CNT.</p> <p>3: The high 8 bits are DMA state machine, and the low 8 bits are SPI state machine.</p> <p>4: Debug signal are read DRQ and write DRQ.</p> <p>2'b0: dqs_rfifo_even water level;</p> <p>4'b0: dqs_rfifo_odd water level.</p>                                                                                                                                                                                                                                                                                                                                                                                       |
| 23:16          | R/W        | 0x0         | <p>CSDA</p> <p>Chip Select De-Assert</p> <p>The interval of two adjacent CS signal enable, namely, the interval of two SPI scheduling. The unit is the i_clk_spi_ref.</p> <p>The minimum interval A (CSDA=0) is 4 clk (used for ending SPI functions)</p> <p>The maximum A (CSDA=FB) is FF clk (used for ending SPI functions)</p> <p>When CSDA is X, the actual interval is X+A.</p>                                                                                                                                                                                                                                               |
| 15:8           | R/W        | 0x6         | <p>CSEOT</p> <p>Chip Select End of Transfer</p> <p>The interval between the rising edge of last output clock signal (SPI_CLK_OUT) and the CS signal disable. The unit is the reference clock</p> <p>The minimum interval B (CSEOT=0) is:</p> <ul style="list-style-type: none"> <li>DTR-TX: 3 clk</li> <li>DTR-RX: 5 clk</li> <li>STR-TX, CPOL=0: 3 clk</li> <li>STR-RX, CPOL=0: 4 clk</li> <li>STR-TX, CPOL=1: 2.5 clk</li> <li>STR-RX, CPOL=1: 3.5 clk</li> </ul> <p>When CSEOT is X, the actual interval is X+B.</p> <p>When using delay, the length of CSEOT should be larger than that of delay, or the data will be lost.</p> |
| 7:0            | R/W        | 0x6         | <p>CSSOT</p> <p>Chip Select Start of Transfer</p> <p>The interval between the CS signal enable and the rising edge of the first output clock signal (SPI_CLK_OUT). The unit is the reference clock.</p> <p>The minimum interval C (CSSOT=0) is:</p> <ul style="list-style-type: none"> <li>CPOL=0: 1 clk</li> <li>CPOL=1: 1.5 clk</li> </ul> <p>When CSSOT is X, the actual interval is X+C.</p> <p>The minimum interval is recommended to be 6, or the</p>                                                                                                                                                                         |

| Offset: 0x001C |            |             | Register Name: SPI_CS_DELAY                                                                                        |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                        |
|                |            |             | anomaly will occur in some special conditions..<br>The minimum interval should be larger than 6 in NEW_START_MODE. |

#### 8.17.6.8 0x0020 SPI Transfer Phase Configure Register (Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: SPI_TRANS_PHA_CFG                                                                                                 |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                      |
| 31:30          | /          | /           | /                                                                                                                                |
| 29             | R/W        | 0x0         | CMD_DTR<br>CMD DTR Control<br>1: CMD DTR<br>0: CMD not DTR<br>CAUTION: When CMD DTR, DTR_EN must be on and CMD2 is required.     |
| 28             | R/W        | 0x0         | COMMAND_TRANS_EN<br>Set to 1 if command data need trans to device<br>SPI Controller FSM Phase Enable<br>1: Enable<br>0: Disable  |
| 27:25          | /          | /           | /                                                                                                                                |
| 24             | R/W        | 0x0         | ADDRESS_TRANS_EN<br>Set to 1 if address need trans to device<br>SPI Controller FSM Phase Enable<br>1: Enable<br>0: Disable       |
| 23:21          | /          | /           | /                                                                                                                                |
| 20             | R/W        | 0x0         | MODE_BIT_TRANS_EN<br>Set to 1 if Mode bit need trans after address<br>SPI Controller FSM Phase Enable<br>1: Enable<br>0: Disable |
| 19:17          | /          | /           | /                                                                                                                                |
| 16             | R/W        | 0x0         | DUMMY_BIT_TRANS_EN<br>Dummy Bit State Enable<br>SPI Controller FSM Phase Enable<br>1: Enable<br>0: Disable                       |
| 15:13          | /          | /           | /                                                                                                                                |
| 12             | R/W        | 0x0         | TX_DATA_EN                                                                                                                       |

| Offset: 0x0020 |            |             | Register Name: SPI_TRANS_PHA_CFG                                                                                                                                                                                  |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                       |
|                |            |             | Set to 1 if Data Need Trans<br>SPI Controller FSM Phase Enable<br>1: Enable<br>0: Disable<br>The CPU channels should be configured before writing to this bit out of protection requirements.                     |
| 11:9           | /          | /           | /                                                                                                                                                                                                                 |
| 8              | R/W        | 0x0         | RX_DATA_EN<br>Set to '1' if Data Need Receive<br>SPI Controller FSM Phase Enable<br>1: Enable<br>0: Disable<br>The CPU channels should be configured before reading from this bit out of protection requirements. |
| 7:0            | /          | /           | /                                                                                                                                                                                                                 |

#### 8.17.6.9 0x0024 SPI Trans Configure1 Register (Default Value: 0x0000\_0000)

| Offset: 0x0024 |            |             | Register Name: SPI_TRANS_CFG1                                                                                                                                                                                                                                                                                                                                                        |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                          |
| 31:0           | R/W        | 0x0         | ADDR_OPCODE<br>Address Content Trans Through SPI<br>When the length of ADDR is configured as 24bit.<br>To configure MSB first, use the low 24 bits of ADDR_OPCODE. Namely, the sending sequence is from bit23 to bit0 in ADDR_OPCODE [23:0].<br>To configure LSB first, use the high 24bits of ADDR_OPCODE. Namely, the sending sequence is from bit8 to bit31 in ADDR_OPCODE[31:8]. |

#### 8.17.6.10 0x0028 SPI Trans Configure2 Register (Default Value: 0x0000\_0000)



#### NOTE

This register should be setup while the controller is idle.

| Offset: 0x0028 |            |             | Register Name: SPI_TRANS_CFG2 |
|----------------|------------|-------------|-------------------------------|
| Bit            | Read/Write | Default/Hex | Description                   |
| 31:24          | R/W        | 0x0         | CMD_OPCODE                    |

| Offset: 0x0028 |            |             | Register Name: SPI_TRANS_CFG2                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                     |
|                |            |             | Command Content Trans Through SPI                                                                                                                                                                                                                                               |
| 23:16          | R/W        | 0x0         | MODE_OPCODE<br>Mode Content Trans Through SPI                                                                                                                                                                                                                                   |
| 15:8           | R/W        | 0x0         | CMD_OPCODE2<br>Command2 Content Trans Through SPI                                                                                                                                                                                                                               |
| 7:6            | R/W        | 0x0         | CMD_TRANS_TYPE<br>Command Transfer Type<br>00: Command can be Shifted to the device on DQ0<br>01: Command can be Shifted to the device on DQ0 and DQ1<br>10: Command can be Shifted to the device on DQ0-DQ3<br>11: Command can be Shifted to the device on DQ0-DQ7             |
| 5:4            | R/W        | 0x0         | ADDR_TRANS_TYPE<br>Address Transfer Type<br>00: Address can be Shifted to the device on DQ0<br>01: Address can be Shifted to the device on DQ0 and DQ1<br>10: Address can be Shifted to the device on DQ0- DQ3<br>11 : Address can be Shifted to the device on DQ0-DQ7          |
| 3:2            | R/W        | 0x0         | MODE_BIT_TRANS_TYPE<br>Mode Bit Transfer Type<br>00: Mode Bit can be Shifted to the device on DQ0<br>01: Mode Bit can be Shifted to the device on DQ0 and DQ1<br>10: Mode Bit can be Shifted to the device on DQ0- DQ3<br>11 : Mode Bit can be Shifted to the device on DQ0-DQ7 |
| 1:0            | R/W        | 0x0         | DATA_TRANS_TYPE<br>Data Transfer Type<br>00: Opcode can be Shifted to the device on DQ0 only<br>01: Opcode can be Shifted to the device on DQ0 and DQ1 only<br>10: Opcode can be Shifted to the device on DQ0- DQ3<br>11 : Opcode can be Shifted to the device on DQ0-DQ7       |

#### 8.17.6.11 0x002C SPI Trans Number Register (Default Value: 0x0000\_0000)

| Offset: 0x002C |            |             | Register Name: SPI_TRANS_NUM |
|----------------|------------|-------------|------------------------------|
| Bit            | Read/Write | Default/Hex | Description                  |
| 31             | R/W        | 0x0         | DATA_TRANS_NUM[16]           |

| Offset: 0x002C |            |             | Register Name: SPI_TRANS_NUM                                                                                                                                                                                                                      |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                       |
| 30:25          | /          | /           | /                                                                                                                                                                                                                                                 |
| 24             | R/W        | 0x0         | ADDR_SIZE_MODE<br>Address Size Mode<br>0: Address Size 24bit.<br>1: Address Size 32bit.                                                                                                                                                           |
| 23:16          | R/W        | 0x0         | DUMMY_TRANS_NUM<br>Number of Dummy Cycles<br>A value of 0 = 1 Cycle<br>A value of 1 = 1 Cycle<br>...<br>A value of N = N Cycle                                                                                                                    |
| 15:0           | R/W        | 0x0         | DATA_TRANS_NUM<br>Num of Data Trans Through SPI(Byte)<br>0: Non-Write.<br>1: Write 1 Byte.<br>2: Write 2 Bytes.<br>3: Write 3 Bytes.<br>.....<br>65535: Write 65535 Bytes.<br>Note: These Bits Indicate Current Operation is Write Data To Flash. |

#### 8.17.6.12 0x0040 SPI DMA Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0040 |            |             | Register Name: SPI_DMA_CTRL                                                                                                                                                                                    |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                    |
| 31:12          | /          | /           | /                                                                                                                                                                                                              |
| 11:4           | R/W        | 0x0         | DMA_DESCRIPTOR_LEN<br>DMA Descriptor Length<br>In the initial design, there are eight DMA descriptors and the length of each descriptor is 4 Byte. In this bit, the length of descriptor is set to 32=8*4Byte. |
| 3:1            | /          | /           | /                                                                                                                                                                                                              |
| 0              | R/WAC      | 0x0         | CFG_DMA_START<br>Config DMA Start Signal<br>When all the DMA parameters are configured well, pull up a pulse of this signal to enable DMA chain.                                                               |

#### 8.17.6.13 0x0044 SPI DMA Descriptor Start Address Register (Default Value: 0x0000\_0000)

| Offset: 0x0044 |            |             | Register Name: SPI_DESCRIPTOR_SADDR                                                     |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                             |
| 31:0           | R/W        | 0x0         | FIRST_DESCRIPTOR_SADDR<br>First Descriptor Start Address<br>The WORD address is needed. |

#### 8.17.6.14 0x004C SPI CDC FIFO Trigger Level Register (Default Value: 0x1001\_1a10)

| Offset: 0x004C |            |             | Name: SPI_CDC_FIFO_TRIG_LEVEL                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                         |
| 31:30          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                   |
| 29:24          | R/W        | 0x10        | WF_DMA_TRIG_LEVEL<br>Write FIFO DMA Request Trigger Level (WORD)<br>In the case of DMA conveying,<br>WF_DMA_TRIG_LEVEL should be set to be less than<br>or equal to 16 to avoid the efficiency reduction.                                                                                                                                           |
| 23:22          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                   |
| 21:16          | R/W        | 0x01        | WF_CPU_TRIG_LEVEL<br>Write FIFO CPU Request Trigger Level (WORD)<br>In the case of DMA conveying, when WF_CNT is less<br>than WF_CPU_TRIG_LEVEL, WF_RDY interrupts will<br>be sent out.                                                                                                                                                             |
| 15:14          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                   |
| 13:8           | R/W        | 0x1a        | RF_FULL_TRIG_LEVEL<br>Read FIFO Full Request Trigger Level (WORD)<br>RF_FULL_TRIG_LEVEL is recommended to be less<br>than or equal to 26 to avoid FIFO anomaly.<br>RF_FULL_TRIG_LEVEL only decides the volume of<br>RX_FIFO, not influencing the RX_RDY_INT.                                                                                        |
| 7:6            | /          | /           | /                                                                                                                                                                                                                                                                                                                                                   |
| 5:0            | R/W        | 0x10        | RF_RDY_TRIG_LEVEL<br>Read FIFO RDY Request Trigger Level (WORD).<br>In the case of CPU reading data, when the rest data<br>volume is larger than RF_RDY_TRIG_LEVEL, and<br>RF_CNT is greater than RF_RDY_TRIG_LEVEL; or the<br>rest data volume is less than RF_RDY_TRIG_LEVEL,<br>and RF_CNT is larger than 1, the RF_RDY_INT will be<br>sent out. |

## 8.17.6.15 0x0050 SPI CDC FIFO Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0050 |            |             | Name: SPI_CDC_FIFO_STA                                                                                                                                                                 |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                            |
| 31:28          | /          | /           | /                                                                                                                                                                                      |
| 27:26          | R          | 0x0         | Flash Controller State Debug Reg.                                                                                                                                                      |
| 25             | R          | 0x0         | WB_WR<br>Write Buffer Could or Not Write.                                                                                                                                              |
| 24:21          | R          | 0x0         | WB_CNT<br>Write Buffer Counter(Byte)<br>These Bits Indicate Number of Bytes in Write Buffer.                                                                                           |
| 20             | R          | 0x0         | RB_RD_RDY_STATE<br>Read Buffer Could or Not Read                                                                                                                                       |
| 19:16          | R          | 0x0         | RB_CNT<br>Read Buffer Counter(Byte)<br>These Bits Indicate Number of Bytes in Read Buffer.                                                                                             |
| 15:14          | /          | /           | /                                                                                                                                                                                      |
| 13:8           | R          | 0x0         | WF_CNT<br>Write FIFO Counter (Level)<br>These Bits Indicate Water Level in Write FIFO.<br>0: 0 level in Write FIFO.<br>1: 1 level in Write FIFO.<br>...<br>32: 32 level in Write FIFO. |
| 7:6            | /          | /           | /                                                                                                                                                                                      |
| 5:0            | R          | 0x0         | RF_CNT<br>Read FIFO Counter (Level)<br>These Bits Indicate Water Level in Read FIFO.<br>0: 0 level in Read FIFO.<br>1: 1 level in Read FIFO.<br>...<br>32: 32 level in Read FIFO.      |

## 8.17.6.16 0x0054 SPI Bit-Aligned Transfer Configure Register (Default Value: 0x0000\_00A0)

| Offset: 0x0054 |            |             | Register Name: SPI_BATC                                                                                                                                       |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                   |
| 31             | R/WAC      | 0x0         | TCE<br>Transfer Control Enable<br>In master mode, it is used to start t1o transfer the serial bit's frame, it is only valid when Work Mode Select==0x10/0x11. |

| Offset: 0x0054 |            |             | Register Name: SPI_BATC                                                                                                                                                                                                                                                                                                                                                    |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                |
|                |            |             | <p>0: Idle<br/>1: Initiates transfer.<br/>Write “1” to this bit will start to transfer serial bits’ frame (the value comes from the SPI TX Bit Register or SPI RX Bit Register), and will auto clear after the bursts transfer completely. Write ‘0’ to this bit has no effect.</p>                                                                                        |
| 30             | R/W        | 0x0         | <p>MSMS<br/>Master Sample Standard<br/>0 - Standard Sample Mode<br/>1 - Delay Sample Mode<br/>In Standard Sample Mode, SPI master samples the data at the standard rising edge of SCLK for each SPI mode;<br/>In Delay Sample Mode, SPI master samples data at the edge that is half cycle delayed by the standard rising edge of SCLK defined in respective SPI mode.</p> |
| 29:26          | /          | /           |                                                                                                                                                                                                                                                                                                                                                                            |
| 25             | R/W1C      | 0x0         | <p>TBC<br/>Transfer Bits Completed<br/>When set, this bit indicates that the last bit of the serial data frame in SPI TX Bit Register (or SPI RX Bit Register) has been transferred completely. Writing 1 to this bit clears it.<br/>0: Busy<br/>1: Transfer Completed<br/>Note: It is only valid when Work Mode Select==0x10/0x11.</p>                                    |
| 24             | R/W        | 0x0         | <p>TBC_INT_EN<br/>Transfer Bits Completed Interrupt Enable<br/>0: Disable<br/>1: Enable<br/>Note: It is only valid when Work Mode Select==0x10/0x11.</p>                                                                                                                                                                                                                   |
| 23:22          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                          |
| 21:16          | R/W        | 0x00        | <p>Configure the length of serial data frame(burst) of RX<br/>000000: 0bit<br/>000001: 1bit<br/>...<br/>100000: 32bits<br/>Other values: reserved</p>                                                                                                                                                                                                                      |

| Offset: 0x0054 |            |             | Register Name: SPI_BATC                                                                                                                                                                                                                                                                                                                                                                               |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                           |
|                |            |             | <b>Note: It is only valid when Work Mode<br/>Select==0x10/0x11, and can't be written when TCE=1.</b>                                                                                                                                                                                                                                                                                                  |
| 15:14          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                     |
| 13:8           | R/W        | 0x00        | Configure the length of serial data frame(burst) of TX<br>000000: 0bit<br>000001: 1bit<br>...<br>100000: 32bits<br>Other values: reserved<br><b>Note: It is only valid when Work Mode<br/>Select==0x10/0x11, and can't be written when TCE=1.</b>                                                                                                                                                     |
| 7              | R/W        | 0x1         | SS_LEVEL<br>When control SS signal manually, set this bit to '1' or '0' to control the level of SS signal.<br>0: set SS to low<br>1: set SS to high<br><b>Note: It is only valid when Work Mode<br/>Select==0x10/0x11, and only work in Mode0, can't be written when TCE=1.</b>                                                                                                                       |
| 6              | R/W        | 0x0         | SS_OWNER<br>SS Output Owner Select<br>Usually, controller sends SS signal automatically with data together. When this bit is set to 1, software must manually write SPI_CTL_REG.SS_LEVEL to 1 or 0 to control the level of SS signal.<br>0: SPI controller<br>1: Software<br><b>Note: It is only valid when Work Mode<br/>Select==0x10/0x11, and only work in Mode0, can't be written when TCE=1.</b> |
| 5              | R/W        | 0x1         | SPOL<br>SPI Chip Select Signal Polarity Control<br>0: Active high polarity (0 = Idle)<br>1: Active low polarity (1 = Idle)<br><b>Note: It is only valid when Work Mode<br/>Select==0x10/0x11, and only work in Mode0, can't be written when TCE=1.</b>                                                                                                                                                |
| 4              | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                     |
| 3:2            | R/W        | 0x0         | SS_SEL<br>SPI Chip Select<br>Select one of four external SPI Master/Slave Devices                                                                                                                                                                                                                                                                                                                     |

| Offset: 0x0054 |            |             | Register Name: SPI_BATC                                                                                                                                                                                                                                    |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                |
|                |            |             | 00: SPI_SS0 will be asserted<br>01: SPI_SS1 will be asserted<br>10: SPI_SS2 will be asserted<br>11: SPI_SS3 will be asserted<br><b>Note: It is only valid when Work Mode Select==0x10/0x11, and only work in Mode0, can't be written when TCE=1.</b>       |
| 1:0            | R/W        | 0x0         | Work Mode Select<br>00: Data frame is byte aligned in Standard SPI, Dual-Output/Dual Input SPI, Dual IO SPI and Quad-Output/Quad-Input SPI.<br>01: Reserve<br>10: Data frame is bit aligned in 3-Wire SPI<br>11: Data frame is bit aligned in Standard SPI |

#### 8.17.6.17 0x0058 SPI Bit-Aligned CLOCK Configuration Register (Default Value: 0x0000\_0000)



##### NOTE

This register is only valid when Work Mode Select==0x10/0x11.

| Offset: 0x0058 |            |             | Register Name: SPI_BA_CCR                                                                                                                                |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                              |
| 31:8           | /          | /           | /                                                                                                                                                        |
| 7:0            | R/W        | 0x0         | CDR_N<br>Clock Divide Rate (Master Mode Only)<br>The SPI_SCLK is determined according to the following equation: SPI_CLK = Source_CLK / (2*(CDR_N + 1)). |

#### 8.17.6.18 0x005C SPI TX Bit Register (Default Value: 0x0000\_0000)



##### NOTE

This register is only valid when Work Mode Select==0x10/0x11.

| Offset: 0x005C |            |             | Register Name: SPI_TBR |
|----------------|------------|-------------|------------------------|
| Bit            | Read/Write | Default/Hex | Description            |

| Offset: 0x005C |            |             | Register Name: SPI_TBR                                                                                                                                                                                   |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                              |
| 31:0           | R/W        | 0x0         | <p>VTB<br/>The Value of the Transmit Bits<br/>This register is used to store the value of the transmitted serial data frame.<br/>Note: In the process of transmission, the LSB is transmitted first.</p> |

#### 8.17.6.19 0x0060 SPI RX Bit Register (Default Value: 0x0000\_0000)



#### NOTE

This register is only valid when Work Mode Select==0x10/0x11.

| Offset: 0x0060 |            |             | Register Name: SPI_RBR                                                                                                                                                                               |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                          |
| 31:0           | R/W        | 0x0         | <p>VRB<br/>The Value of the Receive Bits<br/>This register is used to store the value of the received serial data frame.<br/>Note: In the process of transmission, the LSB is transmitted first.</p> |

#### 8.17.6.20 0x0064 SPI STATUS Register (Default Value: 0x0000\_0885)

| Offset: 0x0064 |            |             | Register Name: SPI_STATUS                                                                                                                                          |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                        |
| 31:24          | R          | 0x0         | READ_STATUS_RESULT                                                                                                                                                 |
| 23:12          | /          | /           | /                                                                                                                                                                  |
| 11:8           | R          | 0x8         | DQS_RF_ODD_WL<br>Rest of space.                                                                                                                                    |
| 7: 4           | R          | 0x8         | DQS_RF_EVEN_WL<br>Rest of space.                                                                                                                                   |
| 3              | R          | 0x0         | <p>WF_FULL<br/>Write FIFO Full Interrupt Flag<br/>0: Write FIFO is Not Full.<br/>1: Write FIFO is Full.<br/>Note: This bit is set when the Write FIFO is full.</p> |
| 2              | R          | 0x1         | <p>WF_EMPTY<br/>Write FIFO Empty Request Interrupt Flag</p>                                                                                                        |

| Offset: 0x0064 |            |             | Register Name: SPI_STATUS                                                                                                                       |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                     |
|                |            |             | 0: Write FIFO always contains one or more bytes.<br>1: Write FIFO has been empty.<br>Note: This bit is set if the Write FIFO is empty.          |
| 1              | R          | 0x0         | RF_FULL<br>Read FIFO Full Interrupt Flag<br>0: Not Full.<br>1: Read FIFO has been Full.<br>Note: This bit is set when Read FIFO is full.        |
| 0              | R          | 0x1         | RF_EMPTY<br>Read FIFO Empty Interrupt Flag<br>0: Not Empty.<br>1: Read FIFO has been Empty.<br>Note: This bit is set if the Read FIFO is empty. |

#### 8.17.6.21 0x0068 SPI STATUS READ Register (Default Value: 0x0000\_0000)

| Offset: 0x0068 |            |             | Register Name: SPI_STATUS_READ                                                                                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                             |
| 31:24          | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                       |
| 23:16          | R/W        | 0x0         | SPI_READ_STATUS_DETECTED_BIT_POSITION<br>These 8 bits are used to distinguish the wanted bit in a STATUS BYTE. For every bit that CPU cares, put a high level in the corresponding bit position.                                                                                                                                                                        |
| 15:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                       |
| 7:0            | R/W        | 0x0         | SPI_READ_STATUS_DETECTED_BIT_VALUE<br>These 8 bits are used to distinguish the wanted bit in a STATUS BYTE. For every bit that CPU cares, put the level that CPU wants in the corresponding bit position. And when one bit is detected the same value, READ_STATUS_MODE shall stop and return a DONE interrupt. Then CPU shall check the exact result in 0x0068[31:24]. |

#### 8.17.6.22 0x006C SPI STATUS READ Register\_2(Default Value: 0x0000\_0000)

| Offset: 0x006C |            |             | Register Name: SPI_STATUS_READ2                                                 |
|----------------|------------|-------------|---------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                     |
| 31:30          | /          | /           | /                                                                               |
| 29:16          | R/W        | 0x0         | MAXIMUM_STATUS_READ_TIME<br>These 14 bits are used to tell the module that when |

| Offset: 0x006C |            |             | Register Name: SPI_STATUS_READ2                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                       |
|                |            |             | reading FLASH status, how many times it should read before it stops reading and instead return a TIME_OUT INTERRUPT to avoid dead lock.<br>NOTE: Suggested minimum value is 1.                                                                                                    |
| 15:14          | /          | /           | /                                                                                                                                                                                                                                                                                 |
| 13:0           | R/W        | 0x0         | READ_STATUS_INTERVAL<br>The INTERVAL is counted with 32KHz clock. These 14 bits are used to tell that when READING STATUS, after how many rising edge of the 32K clock should the module start a READ STATUS visit to the connected FLASH.<br>NOTE: Suggested minimum value is 1. |

#### 8.17.6.23 0x0210 SPI RX Data Register (Default Value: 0x0000\_0000)

| Offset: 0x0210 |            |             | Register Name: SPI_RX_DATA                              |
|----------------|------------|-------------|---------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                             |
| 31:0           | R/W        | 0x0         | SPI_RX_DATA<br>SPI RX Data. Non read when DMA transfer. |

#### 8.17.6.24 0x0220 SPI TX Data Register (Default Value: 0x0000\_0000)

| Offset: 0x0220 |            |             | Register Name: SPI_TX_DATA                               |
|----------------|------------|-------------|----------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                              |
| 31:0           | R/W        | 0x0         | SPI_TX_DATA<br>SPI TX Data. Non write when DMA transfer. |

## 8.18 UART

### 8.18.1 Overview

The universal asynchronous receiver transmitter (UART) provides an asynchronous serial communication with external devices, modem (data carrier equipment, DCE). It performs serial-to-parallel conversion on the data received from peripherals and transmits the converted data to the internal bus. It also performs parallel-to-serial conversion on the data that is transmitted to peripherals.

The UART has the following features:

- Up to 10 UART controllers
  - 8 UART controllers in CPUX domain: UART0, UART1, UART2, UART3, UART4, UART5, UART6, and UART7
  - 2 UART controllers in CPUS domain: S\_UART0 and S\_UART1
- Compatible with industry-standard 16450/16550 UARTs
- Two separate FIFOs: one is RX FIFO, and the other is TX FIFO
  - Each of them is 64 bytes for UART0, S\_UART0, and S\_UART1
  - Each of them is 128 bytes for UART1, UART2, UART3, UART4, UART5, UART6, and UART7
- The working reference clock is from the APB bus clock
  - Speed up to 10 Mbit/s with 160 MHz APB clock (excluding S\_UART0 and S\_UART1)
  - Speed up to 5 Mbit/s with 80 MHz APB clock (excluding S\_UART0 and S\_UART1)
  - Speed up to 3.75 Mbit/s with 60 MHz APB clock (excluding S\_UART0 and S\_UART1)
  - Speed up to 1.5 Mbit/s with 24 MHz APB clock
- 5 to 8 data bits for RS-232 characters, or 9 bits RS-485 format
- 1, 1.5 or 2 stop bits
- Programmable parity (even, odd, or no parity)
- Supports TX/RX DMA slave controller interface
- Supports software/hardware flow control
- Supports IrDA-compatible slow infrared (SIR) format
- Supports auto-flow by using CTS & RTS (excluding UART0, S\_UART0, and S\_UART1)

## 8.18.2 Block Diagram

The following figure shows a block diagram of the UART.

**Figure 8-129 UART Block Diagram**



## 8.18.3 Functional Description

### 8.18.3.1 External Signals

The following table describes the external signals of UART.

**Table 8-58 UART External Signals**

| Signal Name | Description                | Type |
|-------------|----------------------------|------|
| UART0-TX    | UART0 Data Transmitter     | O    |
| UART0-RX    | UART0 Data Receiver        | I    |
| UART1-TX    | UART1 Data Transmitter     | O    |
| UART1-RX    | UART1 Data Receiver        | I    |
| UART1-CTS   | UART1 Data Clear to Send   | I    |
| UART1-RTS   | UART1 Data Request to Send | O    |
| UART2-TX    | UART2 Data Transmitter     | O    |
| UART2-RX    | UART2 Data Receiver        | I    |
| UART2-CTS   | UART2 Data Clear to Send   | I    |
| UART2-RTS   | UART2 Data Request to Send | O    |
| UART3-TX    | UART3 Data Transmitter     | O    |
| UART3-RX    | UART3 Data Receiver        | I    |

| Signal Name | Description                | Type |
|-------------|----------------------------|------|
| UART3-CTS   | UART3 Data Clear to Send   | I    |
| UART3-RTS   | UART3 Data Request to Send | O    |
| UART4-TX    | UART4 Data Transmitter     | O    |
| UART4-RX    | UART4 Data Receiver        | I    |
| UART4-CTS   | UART4 Data Clear to Send   | I    |
| UART4-RTS   | UART4 Data Request to Send | O    |
| UART5-TX    | UART5 Data Transmitter     | O    |
| UART5-RX    | UART5 Data Receiver        | I    |
| UART5-CTS   | UART5 Data Clear to Send   | I    |
| UART5-RTS   | UART5 Data Request to Send | O    |
| UART6-TX    | UART6 Data Transmitter     | O    |
| UART6-RX    | UART6 Data Receiver        | I    |
| UART6-CTS   | UART6 Data Clear to Send   | I    |
| UART6-RTS   | UART6 Data Request to Send | O    |
| UART7-TX    | UART7 Data Transmitter     | O    |
| UART7-RX    | UART7 Data Receiver        | I    |
| UART7-CTS   | UART7 Data Clear to Send   | I    |
| UART7-RTS   | UART7 Data Request to Send | O    |
| S-UART0-TX  | S-UART0 Data Transmitter   | O    |
| S-UART0-RX  | S-UART0 Data Receiver      | I    |
| S-UART1-TX  | S-UART1 Data Transmitter   | O    |
| S-UART1-RX  | S-UART1 Data Receiver      | I    |

### 8.18.3.2 Clock Sources

The following table describes the clock sources of UART.

**Table 8-59 UART Clock Sources**

| UART Interfaces  | Clock Source | Description                                             | Clock Module |
|------------------|--------------|---------------------------------------------------------|--------------|
| UART0 to UART7   | APB1 Bus     | UART clock source. Refer to CCU for details on APB1.    | CCU          |
| S_UART0, S_UART1 | APBS1 Bus    | S_UART clock source. Refer to PRCM for details on APB1. | PRCM         |

### 8.18.3.3 Typical Applications and Timing Diagram

#### UART Serial Data Format

The following figure shows the UART serial data format. The start bit, data bit, parity bit, and stop bit can be configured.

**Figure 8-130** UART Serial Data Format



#### Using UART for RTS/CTS Autoflow Control

Figure 8-131 shows the typical application diagram for RTS/CTS autoflow control. Figure 8-132 shows the data format of the RTS/CTS autoflow control.

**Figure 8-131** Application Diagram for RTS/CTS Autoflow Control



**Figure 8-132** RTS/CTS Autoflow Control Data Format



#### Using UART for Serial IrDA

Figure 8-133 shows the application diagram for the IrDA transceiver. Figure 8-134 shows the data format of the serial IrDA.

Figure 8-133 Application Diagram for IrDA Transceiver



Figure 8-134 Serial IrDA Data Format



### Using UART for RS-485

Figure 8-135 shows the application diagram for the RS-485 transceiver. Figure 8-136 shows the data format of the RS-485.

Figure 8-135 Application Diagram for RS-485 Transceiver



Figure 8-136 RS-485 Data Format



### 8.18.3.4 UART Operating Mode

#### Data Frame Format

The [UART\\_LCR](#) register can set the basic parameter of a data frame: data width (5 to 8 bits), stop bit number (1/1.5/2), parity type.

A frame transfer of the UART includes the start signal, data signal, parity bit, and stop signal. The LSB is transmitted first.

- Start signal (start bit): It is the start flag of a data frame. According to the UART protocol, the low level of the TXD signal indicates the start of a data frame. When the UART transmits data, the level needs to hold high.
- Data signal (data bit): The data bit width can be configured as 5-bit, 6-bit, 7-bit, and 8-bit through different applications. If RS-485 mode is enabled, the data bit width is 8-bit.
- Parity bit: It is a 1-bit error correction signal. Parity bit includes odd parity, even parity. The UART can enable and disable the parity bit by setting the [UART\\_LCR](#) register. If RS-485 mode is enabled, the parity bit must be kept enabled.
- Stop Signal (stop bit): It is the stop bit of a data frame. The stop bit can be set to 1-bit, 1.5-bit, and 2-bit by the [UART\\_LCR](#) register. The high level of the TXD signal indicates the end of a data frame.

#### Baud and Error Rates

The baud rate is calculated as follows: Baud rate = SCLK/(16 \* divisor).

The SCLK is usually APB1 and can be set in section 2.5 Clock Controller Unit (CCU).

The divisor is frequency divider of UART. The frequency divider has 16-bit, the low 8-bit is in the [UART\\_DLL](#) register, the high 8-bit is in the [UART\\_DLH](#) register.

The relationship between the different UART mode and the error rate is as follows.

**Table 8-60 UART Mode Baud and Error Rates**

| Clock Source | Divisor | Baud Rate | Over Sampling | Error(%) |
|--------------|---------|-----------|---------------|----------|
| 24000000     | 5000    | 300       | 16            | 0        |
| 24000000     | 2500    | 600       | 16            | 0        |
| 24000000     | 1250    | 1200      | 16            | 0        |
| 24000000     | 625     | 2400      | 16            | 0        |
| 24000000     | 313     | 4800      | 16            | -0.16    |
| 24000000     | 156     | 9600      | 16            | 0.16     |
| 24000000     | 78      | 19200     | 16            | 0.16     |
| 24000000     | 39      | 38400     | 16            | 0.16     |
| 24000000     | 26      | 57600     | 16            | 0.16     |
| 24000000     | 13      | 115200    | 16            | 0.16     |
| 48000000     | 13      | 230400    | 16            | 0.16     |
| 60000000     | 1       | 3750000   | 16            | 0        |

| Clock Source | Divisor | Baud Rate | Over Sampling | Error(%) |
|--------------|---------|-----------|---------------|----------|
| 75000000     | 5       | 921600    | 16            | 1.725    |
| 48000000     | 3       | 1000000   | 16            | 0        |
| 24000000     | 1       | 1500000   | 16            | 0        |
| 48000000     | 1       | 3000000   | 16            | 0        |
| 80000000     | 1       | 5000000   | 16            | 0        |
| 160000000    | 1       | 10000000  | 16            | 0        |

**Table 8-61 IrDA Mode Baud and Error Rates**

| Clock source | Divisor | Baud rate | Encoding | Error(%) |
|--------------|---------|-----------|----------|----------|
| 24000000     | 5000    | 300       | 3/16     | 0        |
| 24000000     | 2500    | 600       | 3/16     | 0        |
| 24000000     | 1250    | 1200      | 3/16     | 0        |
| 24000000     | 625     | 2400      | 3/16     | 0        |
| 24000000     | 313     | 4800      | 3/16     | -0.16    |
| 24000000     | 156     | 9600      | 3/16     | 0.16     |
| 24000000     | 78      | 19200     | 3/16     | 0.16     |
| 24000000     | 39      | 38400     | 3/16     | 0.16     |
| 24000000     | 26      | 57600     | 3/16     | 0.16     |
| 24000000     | 13      | 115200    | 3/16     | 0.16     |

**Table 8-62 RS485 Mode Baud and Error Rates**

| Clock source | Divisor | Baud rate | Encoding | Error(%) |
|--------------|---------|-----------|----------|----------|
| 24000000     | 5000    | 300       | 16       | 0        |
| 24000000     | 2500    | 600       | 16       | 0        |
| 24000000     | 1250    | 1200      | 16       | 0        |
| 24000000     | 625     | 2400      | 16       | 0        |
| 24000000     | 313     | 4800      | 16       | -0.16    |
| 24000000     | 156     | 9600      | 16       | 0.16     |
| 24000000     | 78      | 19200     | 16       | 0.16     |
| 24000000     | 39      | 38400     | 16       | 0.16     |
| 24000000     | 26      | 57600     | 16       | 0.16     |
| 24000000     | 13      | 115200    | 16       | 0.16     |
| 48000000     | 13      | 230400    | 16       | 0.16     |
| 60000000     | 1       | 3750000   | 16       | 0        |
| 75000000     | 5       | 921600    | 16       | 1.725    |
| 48000000     | 3       | 1000000   | 16       | 0        |
| 24000000     | 1       | 1500000   | 16       | 0        |
| 48000000     | 1       | 3000000   | 16       | 0        |
| 80000000     | 1       | 5000000   | 16       | 0        |
| 160000000    | 1       | 10000000  | 16       | 0        |

## DLAB Definition

The DLAB control bit ([UART\\_LCR](#)[7]) is the access control bit of the divisor Latch register.

If DLAB is 0, then the 0x00 offset address is the [UART\\_RBR/UART\\_THR](#) (RX/TX FIFO) register, and the 0x04 offset address is the [UART\\_IER](#) register.

If DLAB is 1, then the 0x00 offset address is the [UART\\_DLL](#) register, and the 0x04 offset address is the [UART\\_DLH](#) register.

When the UART initializes, the divisor needs to be set. That is, writing 1 to DLAB can access the [UART\\_DLL](#) and [UART\\_DLH](#) register, after finished the configuration, writing 0 to DLAB can access the [UART\\_RBR/UART\\_THR](#) register.

## CHCFG\_AT\_BUSY Definition

The function of the CHCFG\_AT\_BUSY ([UART\\_HALT](#) [1]) and CHANGE\_UPDATE ([UART\\_HALT](#)[2]) are as follows.

CHCFG\_AT\_BUSY: Enable the bit, the software can also set the UART controller when UART is busy, such as the [UART\\_LCR](#), [UART\\_DLH](#), [UART\\_DLL](#) register.

CHANGE\_UPDATE: If CHCFG\_AT\_BUSY is enabled, and CHANGE\_UPDATE is written to 1, the configuration of the UART controller can be updated. After completed the update, the bit is cleared to 0 automatically.

Setting divisor performs the following steps:

Write 1 to CHCFG\_AT\_BUSY to enable “configure at busy”.

Write 1 to DLAB ([UART\\_LCR](#)[7]) and set the [UART\\_DLH](#) and [UART\\_DLL](#) registers.

Write 1 to CHANGE\_UPDATE to update the configuration. The bit is cleared to 0 automatically after completing the update.

## UART Busy Flag

The [UART\\_USR](#) [0] is a busy flag of the UART controller.

When the TX transmits data, or the RX receives data, or the TX FIFO is not empty, or the RX FIFO is not empty, then the busy flag bit can be set to 1 by hardware, which indicates the UART controller is busy.

## 8.18.4 Programming Guidelines

The following takes the UART module in the CPUX domain as an example.

### 8.18.4.1 Initialization

#### Step 1 System Initialization

- Configure [APB1\\_CLK\\_REG](#) in the CCU module to set the APB1 bus clock (The clock is 24MHz by default).

- Set [UART\\_BGR\\_REG](#)[UARTx\_GATING] to 1 to enable the module clock, and set [UART\\_BGR\\_REG](#)[UARTx\_RST] to 1 to de-assert the module.

## Step 2 UART Controller Initialization

- IO configuration: Configure GPIO multiplex as UART function, and set UART pins to internal pull-up mode (For detail, see the description in section 8.5 GPIO).
- Baud-rate configuration:
  - Set UART baud-rate (refer to section 8.18.3.4);
  - Write [UART\\_FCR](#)[FIFOE] to 1 to enable TX/RX FIFO;
  - Write [UART\\_HALT](#)[HALT\_TX] to 1 to disable TX transfer;
  - Set [UART\\_LCR](#)[DLAB] to 1, remain default configuration for other bits; set 0x00 offset address to the [UART\\_DLL](#) register, set 0x04 offset address to the [UART\\_DLH](#) register;
  - Write the high 8-bit of divisor to the [UART\\_DLH](#) register, and write the low 8-bit of divisor to the [UART\\_DLL](#) register;
  - Set [UART\\_LCR](#)[DLAB] to 0, remain default configuration for other bits; set 0x00 offset address to the [UART\\_RBR/UART\\_THR](#) register, set 0x04 offset address to the [UART\\_IER](#) register;
  - Set [UART\\_HALT](#)[HALT\_TX] to 0 to enable TX transfer.

## Step 3 Controller Parameter Configuration

- Set data width, stop bits, and even/odd parity type by writing the [UART\\_LCR](#) register.
- Reset, enable FIFO and set FIFO trigger condition by writing the [UART\\_FCR](#) register.
- Set the flow control parameter by writing the [UART\\_MCR](#) register.

## Step 4 Interrupt Configuration

- Configure UART interrupt vector number to request UART interrupt (Refer to section 2.7 Generic Interrupt Controller (GIC) for interrupt vector number).
- In DMA mode, write [UART\\_IER](#) to 0 to disable interrupt; write [UART\\_HSK](#)[Handshake configuration] to 0xE5 to set DMA handshake mode; write [UART\\_FCR](#)[DMAM] to 1 to set DMA transmission/reception mode; set DMA parameter and request DMA interrupt according to DMA configuration process.
- In Interrupt mode, configure [UART\\_IER](#) to enable the corresponding interrupt according to requirements: such as transmit (TX) interrupt, receive (RX) interrupt, receive line status interrupt, RS48 interrupt, etc. (Here TX/RX interrupt is usually used).

#### 8.18.4.2 Transferring/Receiving Data in DMA Mode

- Step 1** Initialize UART model. Refer to section 8.18.4.1 Initialization for initialization steps.
- Step 2** Configure UART\_TFL and UART\_RFL to set DRQ trigger level for DMA.
- Step 3** Configure UART\_HALT to set PTE and DMA\_PTE\_RX.
- Step 4** DMA data channel, including the transfer source address, the transfer destination address, the number of data to be transferred, and the transfer type, and so on. For details, see section 2.6 DMA Controller (DMAC).
- Step 5** Enable the DMA transfer or receive function of the UART by setting the register of the DMA module.
- Step 6** Determine whether UART data is transferred or received completely based on the DMA status. If all data is transferred or received completely, disable the DMA transfer or receive function of the UART.

#### 8.18.4.3 Transferring/Receiving Data in Interrupt Mode

- Data transfer

- Step 1** Initialize UART model. Refer to section 8.18.4.1 for initialization steps.
- Step 2** Configure UART\_TFL and UART\_RFL to set DRQ trigger level for DMA.
- Step 3** Configure UART\_HALT to set PTE and DMA\_PTE\_RX.
- Step 4** Set UART\_IER[ETBEI] to 1 to enable the UART transmission interrupt.
- Step 5** Write the data to be transmitted to UART\_THR.
- Step 6** When the data of TX\_FIFO meets trigger condition (such as FIFO/2, FIFO/4), the UART transfer interrupt is generated.
- Step 7** Check UART\_USR[TFE] and determine whether TX\_FIFO is empty. If UART\_USR[TFE] is 1, it indicates that the data in TX\_FIFO is transmitted completely.
- Step 8** Clear UART\_IER[ETBEI] to 0 to disable transfer interrupt.

- Data receive

- Step 1** Initialize UART model. Refer to section 8.18.4.1 for initialization steps.
- Step 2** Configure UART\_TFL and UART\_RFL to set DRQ trigger level for DMA.
- Step 3** Configure UART\_HALT to set PTE and DMA\_PTE\_RX.
- Step 4** Set UART\_IER[ERBFI] to 1 to enable the UART reception interrupt.

**Step 5** When the received data from RX\_FIFO meets trigger condition (such as FIFO/2, FIFO/4), the UART receive interrupt is generated.

**Step 6** Read data from [UART\\_RBR](#).

**Step 7** Check RX\_FIFO status by reading [UART\\_USR](#)[RFNE] and determine whether to read data. If the bit is 1, continue to read data from [UART\\_RBR](#) until [UART\\_USR](#)[RFNE] is cleared to 0, which indicates data is received completely.

#### 8.18.4.4 Transferring/Receiving Data in RS485 Mode

**Step 1** Initialize UART model. Refer to section 8.18.4.1 for initialization steps.

**Step 2** Configure UART\_485\_CTL [1:0] to select UART RS485 receive data format.

**Step 3** If AAD receive data mode is choosed, configure UART\_RS485\_ADDR\_MATCH register to set receive address in AAD mode.

**Step 4** If DMA mode is selected, perform Step2 to Step6 in section 8.18.4.2. Otherwise, perform Step2 to Step7 in section 8.18.4.3.

#### 8.18.5 Register List

| Module Name | Base Address |
|-------------|--------------|
| UART0       | 0x02500000   |
| UART1       | 0x02500400   |
| UART2       | 0x02500800   |
| UART3       | 0x02500C00   |
| UART4       | 0x02501000   |
| UART5       | 0x02501400   |
| UART6       | 0x02501800   |
| UART7       | 0x02501C00   |
| S_UART0     | 0x07080000   |
| S_UART1     | 0x07080400   |

| Register Name | Offset | Description                      |
|---------------|--------|----------------------------------|
| UART_RBR      | 0x0000 | UART Receive Buffer Register     |
| UART_THR      | 0x0000 | UART Transmit Holding Register   |
| UART_DLL      | 0x0000 | UART Divisor Latch Low Register  |
| UART_DLH      | 0x0004 | UART Divisor Latch High Register |
| UART_IER      | 0x0004 | UART Interrupt Enable Register   |
| UART_IIR      | 0x0008 | UART Interrupt Identity Register |
| UART_FCR      | 0x0008 | UART FIFO Control Register       |
| UART_LCR      | 0x000C | UART Line Control Register       |

| Register Name         | Offset | Description                                      |
|-----------------------|--------|--------------------------------------------------|
| UART_MCR              | 0x0010 | UART Modem Control Register                      |
| UART_LSR              | 0x0014 | UART Line Status Register                        |
| UART_MSR              | 0x0018 | UART Modem Status Register                       |
| UART_SCH              | 0x001C | UART Scratch Register                            |
| UART_USR              | 0x007C | UART Status Register                             |
| UART_TFL              | 0x0080 | UART Transmit FIFO Level Register                |
| UART_RFL              | 0x0084 | UART Receive FIFO Level Register                 |
| UART_HSK              | 0x0088 | UART DMA Handshake Configuration Register        |
| UART_DMA_REQ_EN       | 0x008C | UART DMA Request Enable Register                 |
| UART_HALT             | 0x00A4 | UART Halt TX Register                            |
| UART_DBG_DLL          | 0x00B0 | UART Debug DLL Register                          |
| UART_DBG_DLH          | 0x00B4 | UART Debug DLH Register                          |
| UART_485_CTL          | 0x00C0 | UART RS485 Control Configure and Status Register |
| UART_RS485_ADDR_MATCH | 0x00C4 | UART RS485 Address Match Register                |
| BUS_IDLE_CHECK        | 0x00C8 | BUS IDLE CHECK Register                          |
| TX_DELAY              | 0x00CC | TX_DELAY Register                                |
| UART_FCC              | 0x00F0 | UART FIFO Clock Control Register                 |

## 8.18.6 Register Description

### 8.18.6.1 0x0000 UART Receiver Buffer Register (Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: UART_RBR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 31:9           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 8:0            | R          | 0           | <p>RBR<br/>Receiver Buffer Register<br/>Data byte received on the serial input port (sin) in UART mode, or the serial infrared input (sir_in) in infrared mode. The data in this register is valid only if the Data Ready (DR) bit in the Line Status Register (LCR) is set.</p> <p>If in FIFO mode and FIFOs are enabled (FCR[0] set to one), this register accesses the head of the receive FIFO. If the receive FIFO is full and this register is not read before the next data character arrives, then the data already in the FIFO is preserved, but any incoming data are lost and an overrun error occurs.</p> |

### 8.18.6.2 0x0000 UART Transmit Holding Register (Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: UART_THR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 7:0            | W          | 0           | <p>THR<br/>Transmit Holding Register<br/>Data to be transmitted on the serial output port (sout) in UART mode or the serial infrared output (sir_out_n) in infrared mode. Data should only be written to the THR when the THR Empty (THRE) bit (LSR[5]) is set.</p> <p>If in FIFO mode and FIFOs are enabled (FCR[0] = 1) and THRE is set, 16 number of characters of data may be written to the THR before the FIFO is full. Any attempt to write data when the FIFO is full results in the write data being lost.</p> |

### 8.18.6.3 0x0000 UART Divisor Latch Low Register (Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: UART_DLL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 7:0            | R/W        | 0           | <p>DLL<br/>Divisor Latch Low<br/>Lower 8 bits of a 16-bit, read/write, Divisor Latch register that contains the baud rate divisor for the UART. This register may only be accessed when the DLAB bit (LCR[7]) is set and the UART is not busy (USR[0] is zero).</p> <p>The output baud rate is equal to the serial clock (sclk) frequency divided by sixteen times the value of the baud rate divisor, as follows: baud rate = (serial clock freq) / (16 * divisor).</p> <p>Note that with the Divisor Latch Registers (DLL and DLH) set to zero, the baud clock is disabled and no serial communications occur. Also, once the DLL is set, at least 8 clock cycles of the slowest UART clock should be allowed to pass before transmitting or receiving data.</p> |

#### 8.18.6.4 0x0004 UART Divisor Latch High Register (Default Value: 0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: UART_DLH                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 7:0            | R/W        | 0           | <p>DLH<br/>Divisor Latch High<br/>Upper 8 bits of a 16-bit, read/write, Divisor Latch register that contains the baud rate divisor for the UART. This register may only be accessed when the DLAB bit (LCR[7]) is set and the UART is not busy (USR[0] is zero).</p> <p>The output baud rate is equal to the serial clock (sclk) frequency divided by sixteen times the value of the baud rate divisor, as follows: baud rate = (serial clock freq) / (16 * divisor).</p> <p>Note that with the Divisor Latch Registers (DLL and DLH) set to zero, the baud clock is disabled and no serial communications occur. Also, once the DLH is set, at least 8 clock cycles of the slowest UART clock should be allowed to pass before transmitting or receiving data.</p> |

#### 8.18.6.5 0x0004 UART Interrupt Enable Register (Default Value: 0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: UART_IER                                                                                                                                    |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                |
| 31:8           | /          | /           | /                                                                                                                                                          |
| 7              | R/W        | 0           | <p>PTIME<br/>Programmable THRE Interrupt Mode Enable<br/>This is used to enable/disable the generation of THRE Interrupt.<br/>0: Disable<br/>1: Enable</p> |
| 6:5            | /          | /           | /                                                                                                                                                          |
| 4              | R/W        | 0           | <p>RS485_INT_EN<br/>RS485 Interrupt Enable<br/>0:Disable<br/>1:Enable</p>                                                                                  |
| 3              | R/W        | 0           | <p>EDSSI<br/>Enable Modem Status Interrupt<br/>This is used to enable/disable the generation of Modem Status Interrupt. This is the fourth highest</p>     |

| Offset: 0x0004 |            |             | Register Name: UART_IER                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                   |
|                |            |             | priority interrupt.<br>0: Disable<br>1: Enable                                                                                                                                                                                                                                                |
| 2              | R/W        | 0           | ELSI<br>Enable Receiver Line Status Interrupt<br>This is used to enable/disable the generation of Receiver Line Status Interrupt. This is the highest priority interrupt.<br>0: Disable<br>1: Enable                                                                                          |
| 1              | R/W        | 0           | ETBEI<br>Enable Transmit Holding Register Empty Interrupt<br>This is used to enable/disable the generation of Transmitter Holding Register Empty Interrupt. This is the third highest priority interrupt.<br>0: Disable<br>1: Enable                                                          |
| 0              | R/W        | 0           | ERBFI<br>Enable Received Data Available Interrupt<br>This is used to enable/disable the generation of Received Data Available Interrupt and the Character Timeout Interrupt (if in FIFO mode and FIFOs enabled). These are the second highest priority interrupts.<br>0: Disable<br>1: Enable |

#### 8.18.6.6 0x0008 UART Interrupt Identity Register (Default Value: 0x0000\_0001)

| Offset: 0x0008 |            |             | Register Name: UART_IIR                                                                                                         |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                     |
| 31:8           | /          | /           | /                                                                                                                               |
| 7:6            | R          | 0           | FEFLAG<br>FIFOs Enable Flag<br>This is used to indicate whether the FIFOs are enabled or disabled.<br>00: Disable<br>11: Enable |
| 5:4            | /          | /           | /                                                                                                                               |
| 3:0            | R          | 0x1         | IID<br>Interrupt ID                                                                                                             |

| Offset: 0x0008 |            |             | Register Name: UART_IIR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                |            |             | <p>This indicates the highest priority pending interrupt which can be one of the following types:</p> <ul style="list-style-type: none"> <li>0000: modem status</li> <li>0001: no interrupt pending</li> <li>0010: THR empty</li> <li>0011: RS485 Interrupt (pending by UART_485_CTL[6:5])</li> <li>0100: received data available</li> <li>0110: receiver line status</li> <li>0111: busy detect</li> <li>1100: character timeout</li> </ul> <p>Bit 3 indicates an interrupt can only occur when the FIFOs are enabled and used to distinguish a Character Timeout condition interrupt.</p> |

| Interrupt ID | Priority Level | Interrupt Type               | Interrupt Source                                                                                                                    | Interrupt Reset                                                                                                                                |
|--------------|----------------|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 0001         | -              | None                         | None                                                                                                                                | -                                                                                                                                              |
| 0110         | Highest        | Receiver line status         | Overrun/parity/ framing errors or break interrupt                                                                                   | Reading the line status register                                                                                                               |
| 0011         | Second         | RS485 Interrupt              | In RS485 mode, receives address data and match setting address                                                                      | Writes 1 to addr flag to reset                                                                                                                 |
| 0100         | Third          | Received data available      | Receiver data available (non-FIFO mode or FIFOs disabled) or RCVR FIFO trigger level reached (FIFO mode and FIFOs enabled)          | Reading the receiver buffer register (non-FIFO mode or FIFOs disabled) or the FIFO drops below the trigger level (FIFO mode and FIFOs enabled) |
| 1100         | Fourth         | Character timeout indication | No characters in or out of the RCVR FIFO during the last 4 character times and there is at least 1 character in it during This time | Reading the receiver buffer register                                                                                                           |
| 0010         | Fifth          | Transmitter holding register | Transmitter holding register empty (Program THRE Mode disabled) or XMIT FIFO at or below                                            | Reading the IIR register (if source of interrupt); or, writing into THR (FIFOs or THRE Mode not selected or disabled) or                       |

| Interrupt ID | Priority Level | Interrupt Type         | Interrupt Source                                                                                                                                                                           | Interrupt Reset                                                       |
|--------------|----------------|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------|
|              |                | empty                  | threshold (Program THRE Mode enabled)                                                                                                                                                      | XMIT FIFO above threshold (FIFOs and THRE Mode selected and enabled). |
| 0000         | Sixth          | Modem status           | Clear to send or data set ready or ring indicator or data carrier detect. Note that if auto flow control mode is enabled, a change in CTS (that is, DCTS set) does not cause an interrupt. | Reading the Modem status Register                                     |
| 0111         | Seventh        | Busy detect indication | UART_16550_COMPATIBLE = NO and master has tried to write to the Line Control Register while the UART is busy (USR[0] is set to one).                                                       | Reading the UART status register                                      |

#### 8.18.6.7 0x0008 UART FIFO Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0008 |            |             | Register Name: UART_FCR                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 7:6            | W          | 0           | <p>RT<br/>RCVR Trigger<br/>This is used to select the trigger level in the receiver FIFO at which the Received Data Available Interrupt is generated. In auto flow control mode it is used to determine when the rts_n signal is de-asserted. It also determines when the dma_rx_req_n signal is asserted in certain modes of operation.</p> <p>00: 1 character in the FIFO<br/>01: FIFO ¼ full<br/>10: FIFO ½ full<br/>11: FIFO-2 less than full</p> |
| 5:4            | W          | 0           | <p>TFT<br/>TX Empty Trigger<br/>This is used to select the empty threshold level at which the THRE Interrupts are generated when the mode is active. It also determines when the</p>                                                                                                                                                                                                                                                                  |

| Offset: 0x0008 |            |             | Register Name: UART_FCR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                |            |             | <p>dma_tx_req_n signal is asserted when in certain modes of operation.</p> <p>00: FIFO empty<br/>01: 2 characters in the FIFO<br/>10: FIFO <math>\frac{1}{4}</math> full<br/>11: FIFO <math>\frac{1}{2}</math> full</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 3              | W          | 0           | <p>DMAM<br/>DMA Mode<br/>0: Mode 0</p> <p>In this mode, when PTE is high and TX FIFO is enable, the TX DMA request will be set when TFL is less than or equal to FIFO Trigger Level(otherwise it will be cleared). When PTE is high and TX FIFO is disabled, the TX DMA request will be set only if THR is empty. If PTE is low, the TX DMA request will be set only if the TX FIFO(TX FIFO Enabled) or THR(TX FIFO Disabled) is empty.</p> <p>When dma_pte_rx is high and RX FIFO is enabled, the rx drq will be set only if RFL is equal to or more than FIFO Trigger Level, otherwise it will be cleared.</p> <p>1: Mode 1</p> <p>In this mode, TX FIFO should be enable. If the PTE is high, the TX DMA request will be set when TFL is less than or equal to FIFO Trigger Level; If PTE is low, the TX DMA request will be set when TX FIFO is empty. Once the request is set, it is cleared only when TX FIFO is full.</p> <p>If RFL is equal to or more than FIFO Trigger Level or there is a character timeout , the rx drq will be set; Once the rx drq is set, it is cleared only when RX FIFO(RX FIFO enabled) or RBR(RX FIFO disabled) is empty.</p> |
| 2              | W          | 0           | <p>XFIFOR<br/>XMIT FIFO Reset</p> <p>This resets the control portion of the transmit FIFO and treats the FIFO as empty. This also de-asserts the DMA TX request.</p> <p>It is 'self-clearing'. It is not necessary to clear this bit.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 1              | W          | 0           | <p>RFIFOR<br/>RCVR FIFO Reset</p> <p>This resets the control portion of the receive FIFO</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

| Offset: 0x0008 |            |             | Register Name: UART_FCR                                                                                                                 |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                             |
|                |            |             | and treats the FIFO as empty. This also de-asserts the DMA RX request.<br>It is 'self-clearing'. It is not necessary to clear this bit. |

#### 8.18.6.8 0x000C UART Line Control Register (Default Value: 0x0000\_0000)

| Offset: 0x000C |            |             | Register Name: UART_LCR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 7              | R/W        | 0           | DLAB<br>Divisor Latch Access Bit<br>It is writable only when UART is not busy (USR[0] is zero) and always readable. This bit is used to enable reading and writing of the Divisor Latch register (DLL and DLH) to set the baud rate of the UART. This bit must be cleared after initial baud rate setup in order to access other registers.<br>0: Select RX Buffer Register (RBR) / TX Holding Register(THR) and Interrupt Enable Register (IER)<br>1: Select Divisor Latch LS Register (DLL) and Divisor Latch MS Register (DLM)  |
| 6              | R/W        | 0           | BC<br>Break Control Bit<br>This is used to cause a break condition to be transmitted to the receiving device. If set to one the serial output is forced to the spacing (logic 0) state. When not in Loopback Mode, as determined by MCR[4], the sout line is forced low until the Break bit is cleared. If SIR_MODE = Enabled and active (MCR[6] set to one) the sir_out_n line is continuously pulsed. When in Loopback Mode, the break condition is internally looped back to the receiver and the sir_out_n line is forced low. |
| 5:4            | R/W        | 0           | EPS<br>Even Parity Select                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

| Offset: 0x000C |            |             | Register Name: UART_LCR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                |            |             | <p>It is writable only when UART is not busy (USR[0] is zero) and always writable readable. This is used to select between even and odd parity, when parity is enabled (PEN set to one). Setting the LCR[5] is unset to reverse the LCR[4].</p> <p>00: Odd Parity<br/>01: Even Parity<br/>1X: Reverse LCR[4]</p> <p>In RS485 mode, it is the 9<sup>th</sup> bit--address bit.<br/>11:9<sup>th</sup> bit = 0, indicates that this is a data byte.<br/>10:9<sup>th</sup> bit = 1, indicates that this is an address byte.</p> <p>Note: When use this function, PEN(LCR[3]) must set to 1.</p>                                                              |
| 3              | R/W        | 0           | <p>PEN<br/>Parity Enable</p> <p>It is writable only when UART is not busy (USR[0] is zero) and always readable. This bit is used to enable and disable parity generation and detection in transmitted and received serial character respectively.</p> <p>0: parity disabled<br/>1: parity enabled</p>                                                                                                                                                                                                                                                                                                                                                    |
| 2              | R/W        | 0           | <p>STOP<br/>Number of stop bits</p> <p>It is writable only when UART is not busy (USR[0] is zero) and always readable. This is used to select the number of stop bits per character that the peripheral transmits and receives. If set to zero, one stop bit is transmitted in the serial data. If set to one and the data bits are set to 5 (LCR[1:0] set to zero) one and a half stop bits is transmitted. Otherwise, two stop bits are transmitted. Note that regardless of the number of stop bits selected, the receiver checks only the first stop bit.</p> <p>0: 1 stop bit<br/>1: 1.5 stop bits when DLS (LCR[1:0]) is zero, else 2 stop bit</p> |
| 1:0            | R/W        | 0           | <p>DLS<br/>Data Length Select</p> <p>It is writable only when UART is not busy (USR[0] is zero) and always readable. This is used to select the</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

| Offset: 0x000C |            |             | Register Name: UART_LCR                                                                                                                                                                                                                                             |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                         |
|                |            |             | <p>number of data bits per character that the peripheral transmits and receives. The number of bit that may be selected areas follows:</p> <ul style="list-style-type: none"> <li>00: 5 bits</li> <li>01: 6 bits</li> <li>10: 7 bits</li> <li>11: 8 bits</li> </ul> |

#### 8.18.6.9 0x0010 UART Modem Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0010 |            |             | Register Name: UART_MCR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 7:6            | R/W        | 0           | <p>UART_FUNCTION<br/>Select IrDA or RS485<br/>0:UART Mode<br/>1:IrDA SIR Mode<br/>2:RS485 Mode<br/>3:Reverse</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 5              | R/W        | 0           | <p>AFCE<br/>Auto Flow Control Enable<br/>When FIFOs are enabled and the Auto Flow Control Enable (AFCE) bit is set, Auto Flow Control features are enabled.<br/>0: Auto Flow Control Mode disabled<br/>1: Auto Flow Control Mode enabled</p>                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 4              | R/W        | 0           | <p>LOOP<br/>Loop Back Mode<br/>0: Normal Mode<br/>1: Loop Back Mode<br/>This is used to put the UART into a diagnostic mode for test purposes. If operating in UART mode (SIR_MODE != Enabled or not active, MCR[6] set to zero), data on the sout line is held high, while serial data output is looped back to the sin line, internally. In this mode all the interrupts are fully functional. Also, in loopback mode, the modem control inputs (dsr_n, cts_n, ri_n, dcd_n) are disconnected and the modem control outputs (dtr_n, rts_n, out1_n, out2_n) are looped back to the inputs, internally. If operating in infrared mode (SIR_MODE == Enabled</p> |

| Offset: 0x0010 |            |             | Register Name: UART_MCR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|                |            |             | AND active, MCR[6] set to one), data on the sir_out_n line is held low, while serial data output is inverted and looped back to the sir_in line.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 3              | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 2              | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 1              | R/W        | 0           | <p>RTS<br/>Request to Send</p> <p>This is used to directly control the Request to Send (rts_n) output. The Request To Send (rts_n) output is used to inform the modem or data set that the UART is ready to exchange data. When Auto RTS Flow Control is not enabled (MCR[5] set to zero), the rts_n signal is set low by programming MCR[1] (RTS) to a high. In Auto Flow Control, AFCE_MODE == Enabled and active (MCR[5] set to one) and FIFOs enable (FCR[0] set to one), the rts_n output is controlled in the same way, but is also gated with the receiver FIFO threshold trigger (rts_n is inactive high when above the threshold). The rts_n signal is de-asserted when MCR[1] is set low.</p> <p>0: rts_n de-asserted (logic 1)<br/>1: rts_n asserted (logic 0)</p> <p>Note that in Loopback mode (MCR[4] set to one), the rts_n output is held inactive high while the value of this location is internally looped back to an input.</p> |
| 0              | R/W        | 0           | <p>DTR<br/>Data Terminal Ready</p> <p>This is used to directly control the Data Terminal Ready (dtr_n) output. The value written to this location is inverted and driven out on dtr_n.</p> <p>0: dtr_n de-asserted (logic 1)<br/>1: dtr_n asserted (logic 0)</p> <p>The Data Terminal Ready output is used to inform the modem or data set that the UART is ready to establish communications.</p> <p>Note that in Loopback mode (MCR[4] set to one), the dtr_n output is held inactive high while the value of this location is internally looped back to an input.</p>                                                                                                                                                                                                                                                                                                                                                                            |

## 8.18.6.10 0x0014 UART Line Status Register (Default Value: 0x0000\_0060)

| Offset: 0x0014 |            |             | Register Name: UART_LSR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 7              | R          | 0           | FIFOERR<br>RX Data Error in FIFO<br>When FIFOs are disabled, this bit is always 0. When FIFOs are enabled, this bit is set to 1 when there is at least one PE, FE, or BI in the RX FIFO. It is cleared by a read from the LSR register provided there are no subsequent errors in the FIFO.                                                                                                                                                                                                                                                                                                                                                       |
| 6              | R          | 1           | TEMT<br>Transmitter Empty<br>If the FIFOs are disabled, this bit is set to "1" whenever the TX Holding Register and the TX Shift Register are empty. If the FIFOs are enabled, this bit is set whenever the TX FIFO and the TX Shift Register are empty. In both cases, this bit is cleared when a byte is written to the TX data channel.                                                                                                                                                                                                                                                                                                        |
| 5              | R          | 1           | THRE<br>TX Holding Register Empty<br>If the FIFOs are disabled, this bit is set to "1" whenever the TX Holding Register is empty and ready to accept new data and it is cleared when the CPU writes to the TX Holding Register.<br>If the FIFOs are enabled, this bit is set to "1" whenever the TX FIFO is empty and it is cleared when at least one byte is written to the TX FIFO.                                                                                                                                                                                                                                                             |
| 4              | R          | 0           | BI<br>Break Interrupt<br>This is used to indicate the detection of a break sequence on the serial input data.<br>If in UART mode (SIR_MODE == Disabled), it is set whenever the serial input, sir_in, is held in a logic '0' state for longer than the sum of <i>start time + data bits + parity + stop bits</i> .<br>If in infrared mode (SIR_MODE == Enabled), it is set whenever the serial input, sir_in, is continuously pulsed to logic '0' for longer than the sum of <i>start time + data bits + parity + stop bits</i> . A break condition on serial input causes one and only one character, consisting of all zeros, to be received by |

| Offset: 0x0014 |            |             | Register Name: UART_LSR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                |            |             | <p>the UART.</p> <p>In the FIFO mode, the character associated with the break condition is carried through the FIFO and is revealed when the character is at the top of the FIFO. Reading the LSR clears the BI bit. In the non-FIFO mode, the BI indication occurs immediately and persists until the LSR is read.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 3              | RC         | 0           | <p>FE<br/>Framing Error</p> <p>This is used to indicate the occurrence of a framing error in the receiver. A framing error occurs when the receiver does not detect a valid STOP bit in the received data.</p> <p>In the FIFO mode, since the framing error is associated with a character received, it is revealed when the character with the framing error is at the top of the FIFO. When a framing error occurs, the UART tries to resynchronize. It does this by assuming that the error was due to the start bit of the next character and then continues receiving the other bit i.e. data, and/or parity and stop. It should be noted that the Framing Error (FE) bit (LSR[3]) is set if a break interrupt has occurred, as indicated by Break Interrupt (BI) bit (LSR[4]).</p> <p>0: no framing error<br/>1:framing error</p> <p>Reading the LSR clears the FE bit.</p> |
| 2              | RC         | 0           | <p>PE<br/>Parity Error</p> <p>This is used to indicate the occurrence of a parity error in the receiver if the Parity Enable (PEN) bit (LCR[3]) is set. In the FIFO mode, since the parity error is associated with a character received, it is revealed when the character with the parity error arrives at the top of the FIFO. It should be noted that the Parity Error (PE) bit (LSR[2]) is set if a break interrupt has occurred, as indicated by Break Interrupt (BI) bit (LSR[4]).</p> <p>0: no parity error<br/>1: parity error</p> <p>Reading the LSR clears the PE bit.</p>                                                                                                                                                                                                                                                                                             |

| Offset: 0x0014 |            |             | Register Name: UART_LSR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 1              | RC         | 0           | <p>OE<br/>Overrun Error<br/>This occurs if a new data character was received before the previous data was read. In the non-FIFO mode, the OE bit is set when a new character arrives in the receiver before the previous character was read from the RBR. When this happens, the data in the RBR is overwritten. In the FIFO mode, an overrun error occurs when the FIFO is full and a new character arrives at the receiver. The data in the FIFO is retained and the data in the receive shift register is lost.</p> <p>0: no overrun error<br/>1: overrun error<br/>Reading the LSR clears the OE bit.</p> |
| 0              | R          | 0           | <p>DR<br/>Data Ready<br/>This is used to indicate that the receiver contains at least one character in the RBR or the receiver FIFO.<br/>0: no data ready<br/>1: data ready<br/>This bit is cleared when the RBR is read in non-FIFO mode, or when the receiver FIFO is empty, in FIFO mode.</p>                                                                                                                                                                                                                                                                                                              |

#### 8.18.6.11 0x0018 UART Modem Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0018 |            |             | Register Name: UART_MSR                                                                                                                                                                                                                                                                                                                                                                            |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                        |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                  |
| 7              | R          | 0           | <p>DCD<br/>Line State of Data Carrier Detect<br/>This is used to indicate the current state of the modem control line dcd_n. This bit is the complement of dcd_n. When the Data Carrier Detect input (dcd_n) is asserted it is an indication that the carrier has been detected by the modem or data set.<br/>0: dcd_n input is de-asserted (logic 1)<br/>1: dcd_n input is asserted (logic 0)</p> |
| 6              | R          | 0           | <p>RI<br/>Line State of Ring Indicator</p>                                                                                                                                                                                                                                                                                                                                                         |

| Offset: 0x0018 |            |             | Register Name: UART_MSR                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                |            |             | <p>This is used to indicate the current state of the modem control line ri_n. This bit is the complement of ri_n. When the Ring Indicator input (ri_n) is asserted it is an indication that a telephone ringing signal has been received by the modem or data set.</p> <p>0: ri_n input is de-asserted (logic 1)<br/>1: ri_n input is asserted (logic 0)</p>                                                                                                                               |
| 5              | R          | 0           | <p>DSR<br/>Line State of Data Set Ready</p> <p>This is used to indicate the current state of the modem control line dsr_n. This bit is the complement of dsr_n. When the Data Set Ready input (dsr_n) is asserted it is an indication that the modem or data set is ready to establish communications with UART.</p> <p>0: dsr_n input is de-asserted (logic 1)<br/>1: dsr_n input is asserted (logic 0)</p> <p>In Loopback Mode (MCR[4] set to one), DSR is the same as MCR[0] (DTR).</p> |
| 4              | R          | 0           | <p>CTS<br/>Line State of Clear To Send</p> <p>This is used to indicate the current state of the modem control line cts_n. This bit is the complement of cts_n. When the Clear to Send input (cts_n) is asserted it is an indication that the modem or data set is ready to exchange data with UART.</p> <p>0: cts_n input is de-asserted (logic 1)<br/>1: cts_n input is asserted (logic 0)</p> <p>In Loopback Mode (MCR[4] = 1), CTS is the same as MCR[1] (RTS).</p>                     |
| 3              | RC         | 0           | <p>DDCD<br/>Delta Data Carrier Detect</p> <p>This is used to indicate that the modem control line dcd_n has changed since the last time the MSR was read.</p> <p>0: no change on dcd_n since last read of MSR<br/>1: change on dcd_n since last read of MSR</p> <p>Reading the MSR clears the DDCD bit.</p> <p>Note: If the DDCD bit is not set and the dcd_n signal is asserted (low) and a reset occurs (software or otherwise), then the DDCD bit is set when the reset is</p>          |

| Offset: 0x0018 |            |             | Register Name: UART_MSR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|                |            |             | removed if the dcd_n signal remains asserted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 2              | RC         | 0           | <p>TERI<br/>Trailing Edge Ring Indicator<br/>This is used to indicate that a change on the input ri_n (from an active-low to an inactive-high state) has occurred since the last time the MSR was read.<br/>0: no change on ri_n since last read of MSR<br/>1: change on ri_n since last read of MSR<br/>Reading the MSR clears the TERI bit.</p>                                                                                                                                                                                                                                         |
| 1              | RC         | 0           | <p>DDSR<br/>Delta Data Set Ready<br/>This is used to indicate that the modem control line dsr_n has changed since the last time the MSR was read.<br/>0: no change on dsr_n since last read of MSR<br/>1: change on dsr_n since last read of MSR<br/>Reading the MSR clears the DDSR bit. In Loopback Mode (MCR[4] = 1), DDSR reflects changes on MCR[0] (DTR).<br/>Note: If the DDSR bit is not set and the dsr_n signal is asserted (low) and a reset occurs (software or otherwise), then the DDSR bit is set when the reset is removed if the dsr_n signal remains asserted.</p>      |
| 0              | RC         | 0           | <p>DCTS<br/>Delta Clear to Send<br/>This is used to indicate that the modem control line cts_n has changed since the last time the MSR was read.<br/>0: no change on ctsdsr_n since last read of MSR<br/>1: change on ctsdsr_n since last read of MSR<br/>Reading the MSR clears the DCTS bit. In Loopback Mode (MCR[4] = 1), DCTS reflects changes on MCR[1] (RTS).<br/>Note: If the DCTS bit is not set and the cts_n signal is asserted (low) and a reset occurs (software or otherwise), then the DCTS bit is set when the reset is removed if the cts_n signal remains asserted.</p> |

#### 8.18.6.12 0x001C UART Scratch Register (Default Value: 0x0000\_0000)

| Offset: 0x001C | Register Name: UART_SCH |
|----------------|-------------------------|
|----------------|-------------------------|

| Bit  | Read/Write | Default/Hex | Description                                                                                                                                     |
|------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8 | /          | /           | /                                                                                                                                               |
| 7:0  | R/W        | 0           | SCRATCH_REG<br>Scratch Register<br>This register is for programmers to use as a temporary storage space. It has no defined purpose in the UART. |

#### 8.18.6.13 0x007C UART Status Register (Default Value: 0x0000\_0006)

| Offset: 0x007C |            |             | Register Name: UART_USR                                                                                                                                                                                                      |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                  |
| 31:5           | /          | /           | /                                                                                                                                                                                                                            |
| 4              | R          | 0           | RFF<br>Receive FIFO Full<br>This is used to indicate that the receive FIFO is completely full.<br>0: Receive FIFO not full<br>1: Receive FIFO Full<br>This bit is cleared when the RX FIFO is no longer full.                |
| 3              | R          | 0           | RFNE<br>Receive FIFO Not Empty<br>This is used to indicate that the receive FIFO contains one or more entries.<br>0: Receive FIFO is empty<br>1: Receive FIFO is not empty<br>This bit is cleared when the RX FIFO is empty. |
| 2              | R          | 1           | TFE<br>Transmit FIFO Empty<br>This is used to indicate that the transmit FIFO is completely empty.<br>0: Transmit FIFO is not empty<br>1: Transmit FIFO is empty<br>This bit is cleared when the TX FIFO is no longer empty. |
| 1              | R          | 1           | TFNF<br>Transmit FIFO Not Full<br>This is used to indicate that the transmit FIFO is not full.<br>0: Transmit FIFO is full<br>1: Transmit FIFO is not full<br>This bit is cleared when the TX FIFO is full.                  |
| 0              | R          | 0           | BUSY                                                                                                                                                                                                                         |

| Offset: 0x007C |            |             | Register Name: UART_USR                         |
|----------------|------------|-------------|-------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                     |
|                |            |             | UART Busy Bit<br>0: Idle or inactive<br>1: Busy |

#### 8.18.6.14 0x0080 UART Transmit FIFO Level Register (Default Value: 0x0000\_0000)

| Offset: 0x0080 |            |             | Register Name: UART_TFL                                                                       |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                   |
| 31:9           | /          | /           | /                                                                                             |
| 8:0            | R          | 0           | TFL<br>Transmit FIFO Level<br>This indicates the number of data entries in the transmit FIFO. |

#### 8.18.6.15 0x0084 UART Receive FIFO Level Register (Default Value: 0x0000\_0000)

| Offset: 0x0084 |            |             | Register Name: UART_RFL                                                                     |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                 |
| 31:9           | /          | /           | /                                                                                           |
| 8:0            | R          | 0           | RFL<br>Receive FIFO Level<br>This indicates the number of data entries in the receive FIFO. |

#### 8.18.6.16 0x0088 UART DMA Handshake Configuration Register (Default Value: 0x0000\_00A5)

| Offset: 0x0088 |            |             | Register Name: UART_HSK                                                          |
|----------------|------------|-------------|----------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                      |
| 31:8           | /          | /           | /                                                                                |
| 7:0            | R/W        | 0xA5        | Handshake configuration<br>0xA5: DMA wait cycle mode<br>0xE5: DMA handshake mode |

#### 8.18.6.17 0x008C UART DMA Request Enable Register (Default Value: 0x0000\_0003)

| Offset: 0x008C |            |             | Register Name: UART_DMA_REQ_EN |
|----------------|------------|-------------|--------------------------------|
| Bit            | Read/Write | Default/Hex | Description                    |
| 31:3           | /          | /           | /                              |
| 2              | R/W        | 0           | DMA Timeout Enable             |

| Offset: 0x008C |            |             | Register Name: UART_DMA_REQ_EN               |
|----------------|------------|-------------|----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                  |
|                |            |             | 0: disable<br>1: enable                      |
| 1              | R/W        | 1           | DMA TX REQ Enable<br>0: disable<br>1: enable |
| 0              | R/W        | 1           | DMA RX REQ Enable<br>0: disable<br>1: enable |

#### 8.18.6.18 0x00A4 UART Halt TX Register (Default Value: 0x0000\_0000)

| Offset: 0x00A4 |            |             | Register Name: UART_HALT                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 31:8           | /          | /           | /                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 7              | R/W        | 0           | DMA_PTE_RX<br>The sending of RX_DRQ.<br>In DMA1 mode, when RFL is more than or equal to trig or receive timeout, send DRQ.<br>In DMA0 mode, when DMA_PTE_RX = 1 and FIFO on, if RFL is more than or equal to trig, send DRQ, else DRQ is cleared. In other cases, once the receive data is valid, send DRQ.                                                                                                                                                                                                                                              |
| 6              | R/W        | 0           | PTE<br>The sending of TX_REQ.<br>In DMA1 mode (FIFO on), if PTE is set 1, when TFL is less than or equal to trig, send the DMA request. If PTE is set 0, when FIFO is empty, send the DMA request. The DMA request will stop when FIFO is full.<br>In DMA0 mode, if PTE is set 1 and FIFO on, when TFL is less than or equal to trig, send DMA request. If PTE is set 1 and FIFO off, when THR is empty, send DMA request. If PTE is set 0, when FIFO(FIFO Enable) or THR(FIFO Enable) is empty, send DMA request.<br>Otherwise, DMA request is cleared. |
| 5              | R/W        | 0           | SIR_RX_INVERT<br>SIR Receiver Pulse Polarity Invert<br>0: Not invert receiver signal<br>1: Invert receiver signal                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 4              | R/W        | 0           | SIR_TX_INVERT<br>SIR Transmit Pulse Polarity Invert                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

| Offset: 0x00A4 |            |             | Register Name: UART_HALT                                                                                                                                                                                                                                                                              |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                                                                                                           |
|                |            |             | 0: Not invert transmit pulse<br>1: Invert transmit pulse                                                                                                                                                                                                                                              |
| 3              | /          | /           | /                                                                                                                                                                                                                                                                                                     |
| 2              | R/WAC      | 0           | CHANGE_UPDATE<br>After the user using HALT[1] to change the baudrate or LCR configuration, write 1 to update the configuration and waiting this bit self clear to 0 to finish update process. Write 0 to this bit has no effect.<br>1: Update trigger, Self clear to 0 when finish update.            |
| 1              | R/W        | 0           | CHCFG_AT_BUSY<br>This is an enable bit for the user to change LCR register configuration (except for the DLAB bit) and baudrate register (DLH and DLL) when the UART is busy (USB[0] is 1).<br>1: Enable change when busy                                                                             |
| 0              | R/W        | 0           | HALT_TX<br>Halt TX<br>This register is use to halt transmissions for testing, so that the transmit FIFO can be filled by the master when FIFOs are implemented and enabled.<br>0 : Halt TX disabled<br>1 : Halt TX enabled<br>Note: If FIFOs are not enabled, the setting has no effect on operation. |

#### 8.18.6.19 0x00B0 UART DBG DLL Register (Default Value: 0x0000\_0000)

| Offset: 0x00B0 |            |             | Register Name: UART_DBG_DLL |
|----------------|------------|-------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                 |
| 31:8           | /          | /           | /                           |
| 7:0            | R          | 0           | DEBUG DLL                   |

#### 8.18.6.20 0x00B4 UART DBG DLH Register (Default Value: 0x0000\_0000)

| Offset: 0x00B4 |            |             | Register Name: UART_DBG_DLH |
|----------------|------------|-------------|-----------------------------|
| Bit            | Read/Write | Default/Hex | Description                 |
| 31:8           | /          | /           | /                           |
| 7:0            | R          | 0           | DEBUG DLH                   |

#### 8.18.6.21 0x00C0 UART RS485 Control Configure and Status Register (Default Value: 0x0000\_0000)

| Offset: 0x00C0 |            |             | Register Name: UART_485_CTL                                                                                                                                          |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                          |
| 31:8           | /          | /           | /                                                                                                                                                                    |
| 7              | R/W        | 0           | Add_bit_polarity<br>Address bit polarity<br>0: The address bit is 1 representative the data is address<br>1: The address bit is 0 representative the data is address |
| 6              | R/W1C      | 0           | AAD_ADDR_Detecte<br>AAD Mode Receive address detecte<br>0:Receive address is different with set<br>1:Receive address is same with set                                |
| 5              | R/W1C      | 0           | Address_detected<br>RS485 Address detect<br>0: No address detected<br>1: address detected                                                                            |
| 4:2            | /          | /           | /                                                                                                                                                                    |
| 1:0            | R/W        | 0           | RCM<br>RS485 Receive mode<br>This is used to chose the RS485 Receive mode<br>00: RS_9BITM<br>01: AAD                                                                 |

#### 8.18.6.22 0x00C4 UART RS485 Address Match Register (Default Value: 0x0000\_0000)

| Offset: 0x00C4 |            |             | Register Name: UART_RS485_ADDR_MATCH         |
|----------------|------------|-------------|----------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                  |
| 31:8           | /          | /           | /                                            |
| 7:0            | R/W        | 0           | AAD_Receive_ADDR<br>AAD Mode Receive address |

#### 8.18.6.23 0x00C8 UART RS485 Bus idle Check Register (Default Value: 0x0000\_0000)

| Offset: 0x00C8 |            |             | Register Name: BUS_IDLE_CHECK                                                              |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                |
| 31:8           | /          | /           | /                                                                                          |
| 7              | R/W        | 0           | BUS_IDLE_CHK_EN<br>1: Enable bus idle check function<br>0: Disable bus idle check function |

| Offset: 0x00C8 |            |             | Register Name: BUS_IDLE_CHECK                              |
|----------------|------------|-------------|------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                |
| 6              | R          | 0           | BUS_STATUS<br>The flag of bus status<br>1:busy<br>0:idle   |
| 5:0            | R          | 0           | ADJ_TIME<br>How long the bus is idle.The unit is 8*16*Tclk |

#### 8.18.6.24 0x00CC UART TX Delay(Default Value: 0x0000\_0000)

| Offset: 0x00CC |            |             | Register Name: TX_DELAY                                                                                                                              |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                          |
| 31:8           | /          | /           | /                                                                                                                                                    |
| 7:0            | R/W        | 0           | DLY<br>The delay time between the last stop bit and the next start bit. The uint is 16*Tclk. It is use to control the space between tow bytes in TX. |

#### 8.18.6.25 0x00F0 UART FIFO Clock Control Register (Default Value: 0x0000\_0003)

| Offset: 0x00F0 |            |             | Register Name: UART_FCC                                                                                                           |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                       |
| 31:8           | R          | 0x0         | FIFO Depth<br>Indicates the depth of TX/RX FIFO                                                                                   |
| 7:3            | /          | /           | /                                                                                                                                 |
| 2              | R/W        | 0           | RXFIFO Clock Mode<br>0: Sync mode, R/W clocks use apb clock<br>1:Sync mode, write clock uses apb clock, read clock uses ahb clock |
| 1              | R/W        | 1           | TX FIFO Clock Enable<br>0: clock disable<br>1: clock enable                                                                       |
| 0              | R/W        | 1           | RX FIFO Clock Enable<br>0: clock disable<br>1: clock enable                                                                       |

# Contents

|                                        |      |
|----------------------------------------|------|
| 9 Security System .....                | 1864 |
| 9.1 Crypto Engine (CE) .....           | 1864 |
| 9.1.1 Overview .....                   | 1864 |
| 9.1.2 Block Diagram .....              | 1866 |
| 9.1.3 Functional Description .....     | 1866 |
| 9.1.4 Programming Guidelines .....     | 1887 |
| 9.1.5 Register List .....              | 1887 |
| 9.1.6 CE_NS Register Description ..... | 1889 |
| 9.1.7 CE_S Register Description .....  | 1894 |

ALLWINNER

# Figures

|                                                                                            |      |
|--------------------------------------------------------------------------------------------|------|
| Figure 9-1 CE Block Diagram .....                                                          | 1866 |
| Figure 9-2 DES Encryption and Decryption .....                                             | 1866 |
| Figure 9-3 3DES Encryption and Decryption of a 3-key Operation and a 2-key Operation ..... | 1867 |
| Figure 9-4 ECB Mode Encryption and Decryption .....                                        | 1868 |
| Figure 9-5 CBC Mode Encryption and Decryption .....                                        | 1869 |
| Figure 9-6 CTR Mode Encryption and Decryption .....                                        | 1870 |
| Figure 9-7 CFB Mode Encryption and Decryption .....                                        | 1871 |
| Figure 9-8 OFB Mode Encryption and Decryption .....                                        | 1872 |
| Figure 9-9 CTS Mode Encryption and Decryption .....                                        | 1873 |
| Figure 9-10 Word Address of Message .....                                                  | 1874 |
| Figure 9-11 Byte Order .....                                                               | 1874 |
| Figure 9-12 Bit Order .....                                                                | 1874 |
| Figure 9-13 The Storage Method of 32-bit IV .....                                          | 1875 |
| Figure 9-14 The Storage Method of 64-bit IV .....                                          | 1875 |
| Figure 9-15 Task Chaining of Hash Algorithms and Random Bit Generator Algorithms .....     | 1877 |
| Figure 9-16 Task Chaining of Other Algorithms .....                                        | 1881 |
| Figure 9-17 Secure Debug Process .....                                                     | 1887 |

# 9 Security System

## 9.1 Crypto Engine (CE)

### 9.1.1 Overview

The Crypto Engine (CE) module is one encryption/decryption algorithms accelerator. It supports kinds of symmetric, asymmetric, HASH, and RBG algorithms. There are two software interfaces for secure and non-secure world each. Algorithm control information is written in memory by task descriptor, then CE automatically reads it when executing request. It supports parallel requests from 4 channels each world and 4 different types of algorithms simultaneously. This module also has an internal DMA controller to transfer data between CE and memory. It supports parallel running for symmetric, HASH, asymmetric algorithms.

The CE has the following features:

- Symmetrical algorithm:
  - AES symmetrical algorithm
    - Key size: 28/192/256 bits
    - CFB mode includes: CFB1, CFB8, CFB64, and CFB128
    - CTR mode includes: CTR16, CTR32, CTR64, and CTR128
    - Supports ECB, CBC, CTS, OFB, CBC-MAC, and GCM modes
  - DES symmetrical algorithm
    - CTR mode, includes: CTR16, CTR32, and CTR64
    - Supports ECB, CBC, and CBC-MAC mode
  - Supports 3DES
  - SM4 symmetrical algorithm supports ECB and CBC mode
- Hash algorithms
  - Support MD5, SHA1, SHA224, SHA256, SHA384, SHA512, and SM3
  - Support HMAC-SHA1, HMAC-SHA256
  - Support multi-package<sup>1</sup> mode for these ones
  - Support hardware padding
- Random bit generator algorithms
  - Support PRNG, 175 bits seed width, and output with multiple of 5 words

<sup>1</sup> If not last package, input should aligned with computation block, namely 512bits or 1024bit

- Support TRNG, post-process by hardware with SHA256, output with multiple of 8 words
- Support Instantiate/Reseed/Generate/Uninstantiate 4 process
- Support prediction resistance requests
- Support 8 separate suits of Internal State
- Maxim 2^32 BYTE length of Entropy input, Nonce, Personalization, Additional input. And length is multiple of word
- Public key algorithms
  - Supports RSA public key algorithms: 512/1024/2048/3072/4096-bit width
  - Supports ECC public key algorithms: 160/224/256/384/521-bit width
  - Supports SM2 algorithms
- Security Strategy and System Feature
  - Symmetric, asymmetric, HASH/RBG ctrl logics are separate, can handle task simultaneously. Symmetric logic can select instantiate 2 suits at implementation time.
  - Support task chain mode for each request. Task or task chain are executed at request order.
  - multi-scatter group(sg) are supported for both input and output data
  - Support secure and non-secure interfaces respectively, each world issues task request through its own interface, don't know each other's existence.
  - Each world has 4 channels for software request, each channel has an interrupt control and status bit, and channels are independent with each other.
  - Supports byte-aligned address for all configurations



#### NOTE

The total length of data\_length in the CBC and ECB modes of the symmetric channels needs to be aligned according to the algorithm granularity. For example, in the AES-128 algorithm, the total length of data\_length needs to be an integer multiple of 128 bits

## 9.1.2 Block Diagram

The following figure shows a block diagram of CE.

**Figure 9-1 CE Block Diagram**



## 9.1.3 Functional Description

### 9.1.3.1 DES Algorithm

The following figure shows the DES encryption and decryption operation.

**Figure 9-2 DES Encryption and Decryption**



### 9.1.3.2 3DES Algorithm

The 3DES algorithm supports both 3-key and 2-key operations. A 2-key operation can be regarded as a simplified 3-key operation. To be specific, key 3 is represented by key 1 in a 2-key operation. The following figure shows the 3DES encryption and decryption operation of a 3-key operation and a 2-key operation.

Figure 9-3 3DES Encryption and Decryption of a 3-key Operation and a 2-key Operation



### 9.1.3.3 ECB Mode

The ECB mode is a confidentiality mode that features, for a given key, the assignment of a fixed ciphertext block to each plaintext block, analogous to the assignment of code words in a codebook.

In ECB mode, encryption and decryption algorithms are directly applied to the block data. The operation of each block is independent, so the plaintext encryption and ciphertext decryption can be performed concurrently.

Figure 9-4 ECB Mode Encryption and Decryption



#### 9.1.3.4 CBC Mode

The CBC mode is a confidentiality mode whose encryption process features the combining of the plaintext blocks with the previous ciphertext blocks. The CBC mode requires an initialization vector (IV) to combine with the first plaintext block. The encryption process of each plaintext block is related to the block processing result of the previous ciphertext blocks, so encryption operations cannot be concurrently performed in CBC mode. The decryption operation is independent of output plain text of the previous block, so decryption operations can be performed concurrently.

**Figure 9-5 CBC Mode Encryption and Decryption**

### 9.1.3.5 CTR Mode

The CTR mode is a confidentiality mode that features the application of the forward cipher to a set of input blocks, called counters, to produce a sequence of output blocks that are exclusive-ORed with the plaintext to produce the ciphertext, and vice versa. All of the counters must be distinct.

Figure 9-6 CTR Mode Encryption and Decryption



#### 9.1.3.6 CFB Mode

The CFB mode is a confidentiality mode that features the feedback of successive ciphertext segments into the input blocks of the forward cipher to generate output blocks that are exclusive-ORed with the plaintext to produce the ciphertext, and vice versa. The CFB mode requires an IV as the initial input block, and the forward cipher operation is applied to the IV to produce the first output block. The first ciphertext segment is produced by exclusive-ORing the first plaintext segment with the s most significant bits of the first output block. The value of s is 1 bit, 8 bits, 64 bits, or 128 bits.

The following figure shows the s-bit CFB mode of the AES algorithms.

**Figure 9-7 CFB Mode Encryption and Decryption**



#### 9.1.3.7 OFB Mode

The OFB mode is a confidentiality mode that features the iteration of the forward cipher on an IV to generate a sequence of output blocks that are exclusive-ORed with the plaintext to produce the ciphertext, and vice versa. If a same key is used, different IVs must be used to ensure operation security.

Figure 9-8 OFB Mode Encryption and Decryption



#### 9.1.3.8 CTS Mode

The CTS mode is a confidentiality mode that accepts any plaintext input whose bit length is greater than or equal to the block size but not necessarily a multiple of the block size. Below are the diagrams for CTS encryption and decryption.

Figure 9-9 CTS Mode Encryption and Decryption



### 9.1.3.9 HASH Algorithm

The hash algorithms support MD5, SHA1, SHA224, SHA256, SHA384, SHA512, HMAC-SHA1, and HMAC-SHA256. All algorithms are iterative, one-way hash functions that can process a message to produce a condensed representation called a message digest. When a message is received, the message digest can be used to verify whether the data has changed, that is, to verify its integrity.

The hash algorithm of the CE supports block-aligned total length of the input data (padded by software), that is, a multiple of 64 bytes. The message length after padding by software is used as the configured data length for the hash algorithm.

### 9.1.3.10 RSA Algorithm

The RSA is a public key encryption/decryption algorithm implemented through the modular exponentiation operation.

The ciphertext is obtained as follows:  $C = M^E \text{ mod } N$ . The plaintext is obtained as follows:  $M = C^D \text{ mod } N$ .

M indicates the plaintext, C indicates the ciphertext, (N, E) indicates the public key, and (N, D) indicates the private key.

### 9.1.3.11 Storing Message

In the application, a message may not be stored contiguously in the memory, but divided into multiple segments. Or a piece of continuously stored messages can be artificially split into multiple pieces as needs. Then each segment corresponds to a set of the source address and source length in the descriptor. Multiple segments correspond to groups 0-7 source address/source length in sequence.

Each task supports up to 8 message segments, and the data volume of each message segment supports up to 4 GWord (AES-CTS is 1 GByte). The total amount of all segments in a task (that is a package) supports up to 4 GWord (AES-CTS is 1 GByte). If a message is divided into multiple packages, all others are required to be whole words; when the last package of AES-CTS is less than one word, 0 needs to be padded, and those less than one word are counted as one word. The following figure shows the address order structure.

Figure 9-10 Word Address of Message



Byte order: low byte first, high byte last. When the data is less than one word, the low byte is filled first. The following figure shows the byte order structure (blue means it is filled by the message).

Figure 9-11 Byte Order



Bit order: high bit first, low bit last. When the data is less than one Byte, the high bit is filled first. The following figure shows the bit order structure.

Figure 9-12 Bit Order



### 9.1.3.12 Storing Key

The length of KEY must be an integer multiple of word.

### 9.1.3.13 Storing IV

For different algorithms, the length of IV is different. But they are integer multiples of word. To keep the byte order of IV and HASH digest output consistent, the byte order of IV is different from that of the message. For the multi-packet operation, the first address of the digest output result of the previous HASH can be directly configured to the first address of the next IV, and the software does not need to do any processing on the digest.

The following figure shows the storage method of 32-bit IV value.

Figure 9-13 The Storage Method of 32-bit IV

|           |                  |
|-----------|------------------|
| IV0[31:0] | BASE_ADDR        |
| IV1[31:0] | BASE_ADDR + 0x04 |
| .....     | .....            |
| IV7[31:0] | BASE_ADDR + 0x1C |

The following figure shows the storage method of 64-bit IV value.

Figure 9-14 The Storage Method of 64-bit IV

|            |                  |
|------------|------------------|
| IV0[63:32] | BASE_ADDR        |
| IV0[31:00] | BASE_ADDR + 0x04 |
| IV1[63:32] | BASE_ADDR + 0x08 |
| IV1[31:00] | BASE_ADDR + 0x0C |
| .....      | .....            |
| IV7[63:32] | BASE_ADDR        |
| IV7[31:00] | BASE_ADDR + 0x3C |

### 9.1.3.14 Task Descriptor of Hash Algorithms and RBG Algorithms

The task descriptor is data written by software to a contiguous space in memory. The data describes the various properties of a task, such as algorithm type, mode, subcommand, key address, data source address, the data size read from data source, abstract destination address, the written destination data size, and the information of other tasks. First, we configure the task descriptor by software; then we operate the registers of CE to start this task. After the task starts, CE will read task descriptor based on the address of the task descriptor configured in register, and perform the task one time based on the described properties.

In applications, the “NEXT TASK ADDR” field can be configured as the starting address of the next task descriptor, to concatenate multi task descriptors into a task chain. After starting the first task, CE will perform every task in order until the “NEXT TASK ADDR” field is invalid (that is 0).

The HASH/RBG algorithms and Symmetrical/Asymmetrical algorithms use the different descriptor structure, separately.



Figure 9-15 Task Chaining of Hash Algorithms and Random Bit Generator Algorithms



The detail structures are as follows.

| No. | Descriptor | Name     | Width   | Description                                                                                                                                                                                                                                                                                                     |
|-----|------------|----------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | CTRL       | CHN      | [1:0]   | Channel ID                                                                                                                                                                                                                                                                                                      |
|     |            | IVE      | [8]     | IV mode enable, active high                                                                                                                                                                                                                                                                                     |
|     |            | LPKG     | [12]    | 1: Multi-SG enable. This bit needs to be fixed as 1.                                                                                                                                                                                                                                                            |
|     |            | DLAV     | [13]    | Data length valid<br>For last package, the bit needs be configured. For non last package, the bit needs not be configured.<br>(Please configure it as 0 in PRNG/TRNG)<br>1: DLA means the WORD address where data total length (by bits) is saved.<br>0: DLA means the value of message total length (by bits). |
|     |            | IE       | [16]    | Interrupt enable for current task, active high                                                                                                                                                                                                                                                                  |
| 1   | CMD        | HASH SEL | [3:0]   | Hash algorithms select<br>0: MD5<br>1: SHA1<br>2: SHA224<br>3: SHA256<br>4: SHA384<br>5: SHA512<br>6: SM3<br>Other: Reserved                                                                                                                                                                                    |
|     |            | HME      | [4]     | HMAC mode enable, active high                                                                                                                                                                                                                                                                                   |
|     |            | RGB SEL  | [11:8]  | RGB algorithms select<br>0: No RGB use<br>1: PRNG<br>2: TRNG<br>Other: Reserved                                                                                                                                                                                                                                 |
|     |            | SUB CMD  | [31:16] | Sub-command in a specific algorithms<br>When using PRNG, sub_cmd[15] means PRNG seed reload; sub_cmd[14:0] means PRNG linearly shifted seed                                                                                                                                                                     |
| 2   | DLA        | DLA      | [31:0]  | Data length OR its address.<br>For last package, the field needs be configured. For non last package, the field needs not be configured.<br>(Not used in PRNG/TRNG)<br>When DLAV=1, here is the WORD address where data total length (by bits) is saved.                                                        |

| No.    | Descriptor | Name      | Width   | Description                                                                                                                                                                               |
|--------|------------|-----------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |            |           |         | When DLAV=0, here is the value of message total length (by bits)                                                                                                                          |
| 3      | DLA        | DLA       | [7:0]   | When DLAV=1, here is the byte address bit[39:32] where data total length (by bits) is saved.                                                                                              |
|        | KA         | KA        | [31:8]  | KEY Address:<br>The byte address bit[23:0].where HMAC KEY or PRNG KEY is saved.                                                                                                           |
| 4      | KA         | KA        | [15:0]  | KEY Address:<br>The byte address bit[39:24].where HMAC KEY or PRNG KEY is saved.                                                                                                          |
|        | IVA        | IVA       | [31:16] | IV Address:<br>The byte address bit[15:0] where IV is saved.                                                                                                                              |
| 5      | IVA        | IVA       | [23:0]  | IV Address:<br>The byte address bit[39:16] where IV is saved.                                                                                                                             |
|        | Reversed   | Reversed  | [31:24] | /                                                                                                                                                                                         |
| 6+5*x  | SGx_W0     | SGx_WORD0 | [31:0]  | Source Data Address x:<br>The byte address bit[31:0] where Source Datax is saved.                                                                                                         |
| 7+5*x  | SGx_W1     | SGx_WORD1 | [7:0]   | Source Data Address x:<br>The byte address bit[39:32] where Source Datax is saved.                                                                                                        |
|        |            |           | [31:8]  | Output Data Address x:<br>The byte address bit[23:0]where Output Datax to be saved.                                                                                                       |
| 8+5*x  | SGx_W2     | SGx_WORD2 | [15:0]  | Output Data Address x:<br>The byte address bit[39:24]where Output Datax to be saved.                                                                                                      |
|        | Reversed   | Reversed  | [31:16] | /                                                                                                                                                                                         |
| 9+5*x  | SGx_W3     | SGx_WORD3 | [31:0]  | Source Data length x:<br>The Length (by bytes) of Source Datax.                                                                                                                           |
| 10+5*x | SGx_W4     | SGx_WORD4 | [31:0]  | Output Data length x:<br>The Length (by bytes) of output Datax.                                                                                                                           |
| 46     | NSA        | NSA       | [31:0]  | Next SG Address:<br>The byte address bit[31:0].where the descriptor of the next 8 sg in a task is saved. If this is the only one group sg or the last group of a task, NSA must be 32'h0. |
| 47     | NSA        | NSA       | [7:0]   | Next SG Address:                                                                                                                                                                          |

| No. | Descriptor | Name     | Width  | Description                                                                                                                                                                                                                                                                                        |
|-----|------------|----------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |            |          |        | The byte address bit[39:32].where the descriptor of the next 8 sg in a task is saved. If this is the only one group sg or the last group of a task, NSA must be 8'h0. The [38] indicate whether the next set of source sg exists.[39] bit indicate whether the next set of output (dst) sg exists. |
|     | NTA        | NTA      | [31:8] | Next task Address:<br>The byte address bit[23:0] where the descriptor of the next task in a task-chain is saved. If this is the only task or the last task of a task-chain, NTA must be 24'h0.                                                                                                     |
| 48  | NTA        | NTA      | [7:0]  | Next task Address:<br>The byte address bit[39:24] where the descriptor of the next task in a task-chain is saved. If this is the only task or the last task of a task-chain, NTA must be 16'h0.                                                                                                    |
| 49  | Reversed   | Reversed | [31:8] | /                                                                                                                                                                                                                                                                                                  |
| 50  | Reversed   | Reversed | /      | /                                                                                                                                                                                                                                                                                                  |
| 51  | Reversed   | Reversed | /      | /                                                                                                                                                                                                                                                                                                  |

### 9.1.3.15 Other Algorithms Task Descriptor

Software make request through task descriptor, providing algorithm type, mode, key address, source/destination sg address and size, etc. The task descriptor is as follows.

**Figure 9-16 Task Chaining of Other Algorithms**



Channel id supports 0-3 for each world.

- Common ctrl

| Bit   | Read/Write | Default | Description                                                                                                                                                                                           |
|-------|------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31    | R/W        | 0       | interrupt enable for current task<br>0: disable interrupt<br>1: enable interrupt                                                                                                                      |
| 30:25 | /          | /       | /                                                                                                                                                                                                     |
| 24:17 | R/W        | 0       | cbc_mac_len<br>the outcome bit length of CBC-MAC when in CBC-MAC mode.<br>The part also be used as gcm/ocb mode tag_len.                                                                              |
| 16:9  | /          | /       | /                                                                                                                                                                                                     |
| 8     | R/W        | 0       | OP DIR<br>Algorithm Operation Direction<br>0: Encryption<br>1: Decryption                                                                                                                             |
| 7     | /          | /       | /                                                                                                                                                                                                     |
| 6:0   | R/W        | 0       | Algorithm type<br>0x0: AES<br>0x1: DES<br>0x2: Triple DES (3DES)<br>0x3: SM4<br>others: reserved<br><br>0x20: RSA<br>0x21: ECC<br>0x22: SM2<br>others: reserved<br><br>0x30: RAES<br>Others: reserved |

- Symmetric ctrl

| Bit   | Read/Write | Default | Description                                                                                    |
|-------|------------|---------|------------------------------------------------------------------------------------------------|
| 31:30 | /          | /       | /                                                                                              |
| 29:28 | R/W        | 0       | SCK_SEL<br>0: use sck0/maskkey0<br>1: use sck1/maskkey1<br>2: use sck2/maskkey2<br>3: reserved |
| 27:24 | /          | /       | /                                                                                              |
| 23:20 | R/W        | 0       | KEY Select<br>key select for AES/SM4/TDES (TDES only configured as                             |

| Bit   | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |            |         | 0/8-15)<br>0: Select input CE_KEYx (Normal Mode)<br>1: Select {SSK}<br>2: Select {HUK}<br>3: Select {RSSK}, used for decrypt EK, BSSK<br>4-7: Reserved<br>8-15: Select internal Key n (n from 0 to 7)                                                                                                                                                                                                                |
| 19:18 | R/W        | 0       | cfb_width<br>For AES-CFB width<br>0: CFB1<br>1: CFB8<br>2: CFB64<br>3: CFB128                                                                                                                                                                                                                                                                                                                                        |
| 17    | /          | /       | /                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 16    | R/W        | 0       | AES CTS last package flag<br>When set to ‘1’ , it means this is the last package for AES-CTS mode(the size of the last package >128bit).<br>The part also be used as gcm/ocb mode<br>gcm_last/ocb_last .                                                                                                                                                                                                             |
| 15:12 | /          | /       | /                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 11:8  | R/W        | 0       | AES/DES/3DES/RAES modes. DES/3DES only supports ECB/CBC/CTR. RAES only supports ECB/CBC operation mode for symmetric<br>0: Electronic Code Book (ECB) mode<br>1: Cipher Block Chaining (CBC) mode<br>2: Counter (CTR) mode<br>3: CipherText Stealing (CTS) mode<br>4: Output feedback (OFB) mode<br>5: Cipher feedback (CFB) mode<br>6: CBC-MAC mode<br>7: OCB mode<br>8: GCM mode<br>9: Reserved<br>Other: reserved |
| 7:6   | /          | /       | /                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 5:4   | R/W        | 0       | gcm_iv_mode[1:0]<br>gcm_iv_mode[0]:value 1 show the last req for iv calculate<br>gcm_iv_mode[1]:<br>0 :no GHASH calculate mode<br>1: GHASH calculate mode<br>gcm_iv_mode[1:0]:<br>00: IDLE state ,this calculate do not have the process from iv to J0.                                                                                                                                                              |

| Bit | Read/Write | Default | Description                                                                                                                                                                                                                                                                                |
|-----|------------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |            |         | 01: by iv padding generating J0. On the mode ,iv padding is 96 bits, so iv_length will be 96bits.<br>10: by GHASH calculate for iv generating J0, and this is not the last req for iv calculate.<br>11: by GHASH calculate for iv generating J0, and this is the last req for iv calculate |
| 3:2 | R/W        | 0       | CTR Width<br>Counter Width for CTR Mode<br>0: 16-bits Counter<br>1: 32-bits Counter, gcm mode always use this setting without software<br>2: 64-bits Counter<br>3: 128-bits Counter                                                                                                        |
| 1:0 | R/W        | 0       | AES Key Size<br>0: 128-bits<br>1: 192-bits<br>2: 256-bits<br>3: Reserved                                                                                                                                                                                                                   |

- Asymmetric ctrl

| Bit   | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------|------------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:21 | /          | /       | /                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 20:16 | R/W        | 0       | PKC algorithm mode.<br>For modular computation:<br>00000: modular exponent(RSA)<br>00001: modular add<br>00010: modular minus<br>00011: modular multiplication<br>others: reserved<br><br>For ECC:<br>00000: point add<br>00001: point double<br>00010: point multiplication<br>00011: point verification<br>00100: encryption<br>00101: decryption<br>00110: sign<br>00111: sign verify<br>others: reserved<br><br>For SM2:<br>00000: encryption |

| Bit  | Read/Write | Default | Description                                                                                            |
|------|------------|---------|--------------------------------------------------------------------------------------------------------|
|      |            |         | 00001: decryption<br>00010: sign<br>00011: sign verify<br>00100: key exchange                          |
| 15:8 | /          | /       | /                                                                                                      |
| 7:0  | R/W        | 0       | Asymmetric algorithms operation width field. It indicates how much width this request apply, as words. |

key addr field is address for each algorithm's key, also for extension feature micro codes address. (By byte)

ctr addr is address for next block's IV. (By byte)

src/dst sgX addr field indicate 40bits address for source and destination data. (By byte)

src/dst sgX size field indicates size for each sg respectively(by byte)

For SG, the detail as flow:



1 group SG has 8 sg, each sg has 5 words, the ADDR is 40 bits and byte-addr; the SIZE is 32bits nad byte-unit. We will support unlimited SG number, but the 1860 just use for test. This can has many group SG in a task, using the next\_sg\_addr to create the new SG information in the task.

Next sg field should be set to 0 when no next group sg, else set to next sg's descriptor.

next task field should be set to 0 when no next task, else set to next task's descriptor.

### 9.1.3.16 PKC Microcode

PKC module supports RSA, ECC, SM2 algorithms in the form of microcode. It implements basic modular add, minus, multiplication, point add, point double, and logic computing, etc. Complete RSA/ECC/SM2 encryption, decryption, sign, verify are implemented with these microcode.

Asymmetric algorithms RSA/ECC/SM2 are implemented as microcode in PKC module. The encryption, decryption, sign, verify operations of asymmetric algorithms are composed with certain fixed microcode with hardware.

#### 9.1.3.17 PKC Configuration

Before starting PKC, task description must be configured. Parameters to PKC are assigned to source sg, outcome is put to destination sg.

For RSA, parameters should be at the order of key, modulus, plaintext.

For ECC point add  $P_2 = P_0 + P_1$ , parameters should be at the order of p, P0x, P0y, P1x, P1y. Output is at the order of P2x, P2y.

For ECC point double  $P_2 = 2*P_0$ , parameters should be at the order of p, a, P0x, P0y. Output is at the order of P2x, P2y.

For ECC point multiplication  $P_2 = k*P_0$ , parameters should be at the order of p, k, a, P0x, P0y. Output is at the order of P2x, P2y.

For ECC point verification, parameters should be at the order of p, a, P0x, P0y, b. Output is 1 or 0.

For ECC encryption, parameters should be at the order of random k, p, a, Gx, Gy, Qx, Qy, m. Output is at the order of Rx, Ry, c.

For ECC decryption, parameters should be at the order of random k, p, a, Rx, Ry, c. Output is m.

For ECC signature, parameters should be at the order of random k, p, a, Gx, Gy, n, d, e. Output is at the order of r, s.

For ECC signature verification, parameters should be at the order of n, s, e, r, p, a, Gx, Gy, Qx, Qy, n, r. Output is 1 or 0.

#### 9.1.3.18 Error Check

After CE reads the task descriptor, CE can monitor error during algorithm operation. When the error is monitored, CE will do the following operations:

The task will pause immediately

Generates interrupt

The corresponding channel of the task status register is Fail

The corresponding channel bit of error status register can be read error number

The error number has the following types.

| Code | Name                  | Description                                                                  | Algorithms Type |
|------|-----------------------|------------------------------------------------------------------------------|-----------------|
| 0x01 | algorithm not support | The algorithm type is not supported.                                         | All             |
| 0x11 | KEYSRAM access error  | In AES decryption task, RSSK is used as plaintext, the DST address is not in | AES decryption  |

| Code | Name                           | Description                                         | Algorithms Type |
|------|--------------------------------|-----------------------------------------------------|-----------------|
|      |                                | KEYSRAM space.                                      |                 |
| 0x21 | key ladder configuration error | /                                                   | KL              |
| 0x31 | data length error              | Input size or output size configuration size error. | All             |

## 9.1.4 Programming Guidelines

### 9.1.4.1 Processing Secure Debug

The following figure shows the secure debug process.

**Figure 9-17 Secure Debug Process**



In secure debug process, CE mainly performs the following operations:

- Signature authentication
- Comparison of hash values of public key and chip\_id
- Transmission of debug mode and transmission of authentication result

## 9.1.5 Register List

There are three groups of registers in

| Module Name      | Base Address | Comments                   |
|------------------|--------------|----------------------------|
| CE_NS            | 0x03040000   | Non-Security CE            |
| CE_S             | 0x03040800   | Security CE                |
| SECURE_DEBUG_CFG | 0x03042000   | Secure Debug Configuration |

### 9.1.5.1 CE\_NS Register List

| Module Name | Base Address | Comments        |
|-------------|--------------|-----------------|
| CE_NS       | 0x03040000   | Non-Security CE |

| Register Name | Offset | Description                                       |
|---------------|--------|---------------------------------------------------|
| CE_TDAO_NS    | 0x0000 | Non-Security CE Task Descriptor Address0 Register |
| CE_TDA1_NS    | 0x0004 | Non-Security CE Task Descriptor Address1 Register |
| CE_ICR_NS     | 0x0008 | Non-Security CE Interrupt Control Register        |
| CE_ISR_NS     | 0x000C | Non-Security CE Interrupt Status Register         |
| CE_TLR_NS     | 0x0010 | Non-Security CE Task Load Register                |
| CE_TSR_NS     | 0x0014 | Non-Security CE Task Status Register              |
| CE_ESR_NS     | 0x0018 | Non-Security CE Error Status Register             |

### 9.1.5.2 CE\_S Register List

| Module Name | Base Address | Comments    |
|-------------|--------------|-------------|
| CE_S        | 0x03040800   | Security CE |

| Register Name | Offset | Description                                                               |
|---------------|--------|---------------------------------------------------------------------------|
| CE_TDAO_S     | 0x0000 | Security CE Task Descriptor Address0 Register                             |
| CE_TDA1_S     | 0x0004 | Security CE Task Descriptor Address1 Register                             |
| CE_ICR_S      | 0x0008 | Security CE Interrupt Control Register                                    |
| CE_ISR_S      | 0x000C | Security CE Interrupt Status Register                                     |
| CE_TLR_S      | 0x0010 | Security CE Task Load Register                                            |
| CE_TSR_S      | 0x0014 | Security CE Task Status Register                                          |
| CE_ESR_S      | 0x0018 | Security CE Error Status Register                                         |
| CE_SCSA0_S    | 0x0020 | Security CE Symmetric algorithm DMA Current Source Address0 Register      |
| CE_SCSA1_S    | 0x0024 | Security CE Symmetric algorithm DMA Current Source Address1 Register      |
| CE_SCDA0_S    | 0x0028 | Security CE Symmetric algorithm DMA Current Destination Address0 Register |
| CE_SCDA1_S    | 0x002C | Security CE Symmetric algorithm DMA Current Destination Address1 Register |
| CE_ACSA0_S    | 0x0030 | Security CE Asymmetric algorithm DMA Current Source Address0 Register     |
| CE_ACSA1_S    | 0x0034 | Security CE Asymmetric algorithm DMA Current Source Address1 Register     |
| CE_ACDA0_S    | 0x0038 | Security CE Asymmetric algorithm DMA Current Destination                  |

| Register Name | Offset | Description                                                                |
|---------------|--------|----------------------------------------------------------------------------|
|               |        | Address0 Register                                                          |
| CE_ACDA1_S    | 0x003C | Security CE Asymmetric algorithm DMA Current Destination Address1 Register |
| CE_HCSA0_S    | 0x0040 | Security CE HASH algorithm DMA Current Source Address0 Register            |
| CE_HCSA1_S    | 0x0044 | Security CE HASH algorithm DMA Current Source Address1 Register            |
| CE_HCDA0_S    | 0x0048 | Security CE HASH algorithm DMA Current Destination Address0 Register       |
| CE_HCDA1_S    | 0x004C | Security CE HASH algorithm DMA Current Destination Address1 Register       |
| CE_XCSA0_S    | 0x0050 | Security CE RAES algorithm DMA Current Source Address0 Register            |
| CE_XCSA1_S    | 0x0054 | Security CE RAES algorithm DMA Current Source Address1 Register            |
| CE_XCDA0_S    | 0x0058 | Security CE RAES algorithm DMA Current Destination Address0 Register       |
| CE_XCDA1_S    | 0x005C | Security CE RAES algorithm DMA Current Destination Address1 Register       |

### 9.1.5.3 SECURE\_DEBUG\_CFG Register List

| Module Name      | Base Address | Comments                   |
|------------------|--------------|----------------------------|
| SECURE_DEBUG_CFG | 0x03042000   | Secure Debug Configuration |

| Register Name   | Offset | Description                           |
|-----------------|--------|---------------------------------------|
| DEBUG_CTRL_AUTH | 0x0000 | Debug Authentication control Register |

### 9.1.6 CE\_NS Register Description

#### 9.1.6.1 0x0000 Non-Security CE Task Descriptor Address0 Register (Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: CE_TDA0_NS                                                 |
|----------------|------------|-------------|---------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                               |
| 31:0           | R/W        | 0x0         | TASK_DES_Address0<br>Task Descriptor Address0<br>is bit[31:0] (byte addr) |

### 9.1.6.2 0x0004 Non-Security CE Task Descriptor Address1 Register (Default Value: 0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: CE_TDA1_NS                                                 |
|----------------|------------|-------------|---------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                               |
| 31:8           | /          | /           | /                                                                         |
| 7:0            | R/W        | 0x0         | TASK_DES_Address1<br>Task Descriptor Address<br>is bit[39:32] (byte addr) |

### 9.1.6.3 0x0008 Non-Security CE Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0008 |            |             | Register Name: CE_ICR_NS                                                                                                                                   |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                |
| 31:6           | /          | /           | /                                                                                                                                                          |
| 5              | /          | /           | HASH_PADDING<br>0: Hardware padding, perform one hash operation<br>within a task.<br>1: Software padding, perform one hash operation in<br>multiple tasks. |
| 4              | /          | /           | /                                                                                                                                                          |
| 3              | R/W        | 0x0         | TASK_CHAN3_INT_EN<br>Channel 3 Task Interrupt Enable<br>0: interrupt disable<br>1: interrupt enable                                                        |
| 2              | R/W        | 0x0         | TASK_CHAN2_INT_EN<br>Channel 2 Task Interrupt Enable<br>0: interrupt disable<br>1: interrupt enable                                                        |
| 1              | R/W        | 0x0         | TASK_CHAN1_INT_EN<br>Channel 1 Task Interrupt Enable<br>0: interrupt disable<br>1: interrupt enable                                                        |
| 0              | R/W        | 0x0         | TASK_CHAN0_INT_EN<br>Channel 0 Task Interrupt Enable<br>0: interrupt disable<br>1: interrupt enable                                                        |

## 9.1.6.4 0x000C Non-Security CE Interrupt Status Register (Default Value: 0x0000\_0000)



The tasks of 4 channels can be calculated in parallel. Therefore, 4 types of interrupts can be pulled high at the same time.

| Offset: 0x000C |            |             | Register Name: CE_ISR_NS                                                                                                                     |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                  |
| 31:8           | /          | /           | /                                                                                                                                            |
| 7:6            | R/W1C      | 0x0         | TASK_CHAN3_STA<br>Channel 3 task Status :<br>Read 0x1: task completed successfully<br>Read 0x2: task fail and stop<br>Write 0x3 to clear it. |
| 5:4            | R/W1C      | 0x0         | TASK_CHAN2_STA<br>Channel 2 task Status :<br>Read 0x1: task completed successfully<br>Read 0x2: task fail and stop<br>Write 0x3 to clear it. |
| 3:2            | R/W1C      | 0x0         | TASK_CHAN1_STA<br>Channel 1 task Status :<br>Read 0x1: task completed successfully<br>Read 0x2: task fail and stop<br>Write 0x3 to clear it. |
| 1:0            | R/W1C      | 0x0         | TASK_CHAN0_STA<br>Channel 0 task Status :<br>Read 0x1: task completed successfully<br>Read 0x2: task fail and stop<br>Write 0x3 to clear it. |

## 9.1.6.5 0x0010 Non-Security CE Task Load Register (Default Value: 0x0000\_0000)

| Offset: 0x0010 |            |         | Register Name: CE_TLR_NS                                                                                                  |
|----------------|------------|---------|---------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default | Description                                                                                                               |
| 31             | R          | 0       | TASK3_F_FULL<br>task FIFO is not full.<br>0: channel 3 is ready to load task.<br>1: channel 3 is busy, can not load task. |
| 30             | R          | 0       | TASK2_F_FULL<br>task FIFO is not full.<br>0: channel 2 is ready to load task.                                             |

| Offset: 0x0010 |            |         | Register Name: CE_TLR_NS                                                                                                                                                                                                                                                                                                   |
|----------------|------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                |
|                |            |         | 1: channel 2 is busy, can not load task.                                                                                                                                                                                                                                                                                   |
| 29             | R          | 0       | TASK1_F_FULL<br>task FIFO is not full.<br>0: channel 1 is ready to load task.<br>1: channel 1 is busy, can not load task.                                                                                                                                                                                                  |
| 28             | R          | 0       | TASK0_F_FULL<br>task FIFO is not full.<br>0: channel 0 is ready to load task.<br>1: channel 0 is busy, can not load task.                                                                                                                                                                                                  |
| 27:20          | /          | /       | /                                                                                                                                                                                                                                                                                                                          |
| 19:16          | R/W        | 0       | Channel Task Load enable<br>When set, channel load task .<br>0001: channel 0 load task enable<br>0010: channel 1 load task enable<br>0100: channel 2 load task enable<br>1000: channel 3 load task enable<br><b>Note: only when the corresponding bit is enabled, the task load signal can be loaded into the channel.</b> |
| 15             | R/W        | 0       | TASK_LOAD_RAES<br>When set, channel 3 can load the descriptor.<br>1: load ares task<br>0: no effect                                                                                                                                                                                                                        |
| 14:11          | /          | /       | /                                                                                                                                                                                                                                                                                                                          |
| 10             | R/W        | 0       | TASK_LOAD_HASH<br>When set, channel 2 can load the descriptor of task.<br>1: load hash task<br>0: no effect                                                                                                                                                                                                                |
| 9:6            | /          | /       | /                                                                                                                                                                                                                                                                                                                          |
| 5              | R/W        | 0       | TASK_LOAD_ASYMM<br>When set, channel 1 can load the descriptor of task.<br>1: load asymm task<br>0: no effect                                                                                                                                                                                                              |
| 4:1            | /          | /       | /                                                                                                                                                                                                                                                                                                                          |
| 0              | R/W        | 0       | TASK_LOAD_SYMM<br>When set, channel 0 can load the descriptor of task.<br>1: load symm task<br>0: no effect                                                                                                                                                                                                                |

#### 9.1.6.6 0x0014 Non-Security CE Task Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0014 | Register Name: CE_TSNS |
|----------------|------------------------|
|----------------|------------------------|

| Bit   | Read/Write | Default/Hex | Description                                                                                                                                      |
|-------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:27 | /          | /           | /                                                                                                                                                |
| 26:24 | R          | 0x0         | TASK_CHAN_RAES<br>indicate which channel is run for RAES.<br>0: task channel0<br>1: task channel1<br>2: task channel2<br>3: task channel3        |
| 23:19 | /          | /           | /                                                                                                                                                |
| 18:16 | R          | 0x0         | TASK_CHAN_DIG<br>indicate which channel is run for digest.<br>0: task channel0<br>1: task channel1<br>2: task channel2<br>3: task channel3       |
| 15:11 | /          | /           | /                                                                                                                                                |
| 10:8  | R          | 0x0         | TASK_CHAN_ASYMM<br>indicate which channel is run for asymmetric.<br>0: task channel0<br>1: task channel1<br>2: task channel2<br>3: task channel3 |
| 7:3   | /          | /           | /                                                                                                                                                |
| 2:0   | R          | 0x0         | TASK_CHAN_SYMM<br>indicate which channel is run for symmetric.<br>0: task channel0<br>1: task channel1<br>2: task channel2<br>3: task channel3   |

#### 9.1.6.7 0x0018 Non-Security CE Error Status Register (Default Value: 0x0000\_0000)



#### NOTE

If data length error occurs, CE needs to be reset. Because, in this case, the computation has already started. In order to ensure that the data FIFO and algorithm state machine are cleared after the error status is cleared, CE needs to be reset to ensure the normal calculation of the next task.

| Offset: 0x0018 |            |             | Register Name: CE_ESR_NS |
|----------------|------------|-------------|--------------------------|
| Bit            | Read/Write | Default/Hex | Description              |
| 31:24          | R          | 0x0         | CHAN3_ERR_STATE          |

| Offset: 0x0018 |            |             | Register Name: CE_ESR_NS                                                                                                                                                                                              |
|----------------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                                                                           |
|                |            |             | Error code for task channel 3<br>0x00: No error<br>0x01: algorithm not support<br>0x11: KEYSRAM access error<br>0x21: key ladder configuration error<br>0x31: data length error<br>other: reserved                    |
| 23:16          | R          | 0x0         | CHAN2_ERR_STATE<br>Error code for task channel 2<br>0x00: No error<br>0x01: algorithm not support<br>0x11: KEYSRAM access error<br>0x21: key ladder configuration error<br>0x31: data length error<br>other: reserved |
| 15:8           | R          | 0x0         | CHAN1_ERR_STATE<br>Error code for task channel 1<br>0x00: No error<br>0x01: algorithm not support<br>0x11: KEYSRAM access error<br>0x21: key ladder configuration error<br>0x31: data length error<br>other: reserved |
| 7:0            | R          | 0x0         | CHAN0_ERR_STATE<br>Error code for task channel 0<br>0x00: No error<br>0x01: algorithm not support<br>0x11: KEYSRAM access error<br>0x21: key ladder configuration error<br>0x31: data length error<br>other: reserved |

### 9.1.7 CE\_S Register Description

#### 9.1.7.1 0x0000 Security CE Task Descriptor Address0 Register (Default Value: 0x0000\_0000)

| Offset: 0x0000 |            |             | Register Name: CE_TDA0_S                                              |
|----------------|------------|-------------|-----------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                           |
| 31:0           | R/W        | 0x0         | TASK.Des_ADDR0<br>Task Descriptor Address<br>is bit[31:0] (byte addr) |

### 9.1.7.2 0x0004 Security CE Task Descriptor Address1 Register (Default Value: 0x0000\_0000)

| Offset: 0x0004 |            |             | Register Name: CE_TDA1_S                                               |
|----------------|------------|-------------|------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                            |
| 31:8           | /          | /           | /                                                                      |
| 7:0            | R/W        | 0x0         | TASK_DES_ADDR1<br>Task Descriptor Address<br>is bit[39:32] (byte addr) |

### 9.1.7.3 0x0008 Security CE Interrupt Control Register (Default Value: 0x0000\_0000)

| Offset: 0x0008 |            |             | Register Name: CE_ICR_S                                                                                                                                    |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                                |
| 31:6           | /          | /           | /                                                                                                                                                          |
| 5              | R/W        | 0x0         | HASH_PADDING<br>0: Hardware padding, perform one hash operation<br>within a task.<br>1: Software padding, perform one hash operation in<br>multiple tasks. |
| 4              | /          | /           | /                                                                                                                                                          |
| 3              | R/W        | 0x0         | TASK_CHAN3_INT_EN<br>Channel 3 Task Interrupt Enable<br>0: interrupt disable<br>1: interrupt enable                                                        |
| 2              | R/W        | 0x0         | TASK_CHAN2_INT_EN<br>Channel 2 Task Interrupt Enable<br>0: interrupt disable<br>1: interrupt enable                                                        |
| 1              | R/W        | 0x0         | TASK_CHAN1_INT_EN<br>Channel 1 Task Interrupt Enable<br>0: interrupt disable<br>1: interrupt enable                                                        |
| 0              | R/W        | 0x0         | TASK_CHAN0_INT_EN<br>Channel 0 Task Interrupt Enable<br>0: interrupt disable<br>1: interrupt enable                                                        |

## 9.1.7.4 0x000C Security CE Interrupt Status Register (Default Value: 0x0000\_0000)



The tasks of 4 channels can be calculated in parallel. Therefore, 4 types of interrupts can be pulled high at the same time.

| Offset: 0x000C |            |             | Register Name: CE_ISR_S                                                                                                                      |
|----------------|------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                                                  |
| 31:8           | /          | /           | /                                                                                                                                            |
| 7:6            | R/W1C      | 0x0         | TASK_CHAN3_STA<br>Channel 3 task Status :<br>Read 0x1: task completed successfully<br>Read 0x2: task fail and stop<br>Write 0x3 to clear it. |
| 5:4            | R/W1C      | 0x0         | TASK_CHAN2_STA<br>Channel 2 task Status :<br>Read 0x1: task completed successfully<br>Read 0x2: task fail and stop<br>Write 0x3 to clear it. |
| 3:2            | R/W1C      | 0x0         | TASK_CHAN1_STA<br>Channel 1 task Status :<br>Read 0x1: task completed successfully<br>Read 0x2: task fail and stop<br>Write 0x3 to clear it. |
| 1:0            | R/W1C      | 0x0         | TASK_CHAN0_STA<br>Channel 0 task Status :<br>Read 0x1: task completed successfully<br>Read 0x2: task fail and stop<br>Write 0x3 to clear it. |

## 9.1.7.5 0x0010 Security CE Task Load Register (Default Value: 0x0000\_0000)

| Offset: 0x0010 |            |         | Register Name: CE_TLR_S                                                                                                      |
|----------------|------------|---------|------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default | Description                                                                                                                  |
| 31             | R          | 0       | CHANNEL3_F_FULL<br>task FIFO is not full.<br>0: channel 3 is ready to load task.<br>1: channel 3 is busy, can not load task. |
| 30             | R          | 0       | CHANNEL2_F_FULL<br>task FIFO is not full.<br>0: channel 2 is ready to load task.                                             |

| Offset: 0x0010 |            |         | Register Name: CE_TLR_S                                                                                                                                                                                                                                                                                                    |
|----------------|------------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default | Description                                                                                                                                                                                                                                                                                                                |
|                |            |         | 1: channel 2 is busy, can not load task.                                                                                                                                                                                                                                                                                   |
| 29             | R          | 0       | CHANNEL1_F_FULL<br>task FIFO is not full.<br>0: channel 1 is ready to load task.<br>1: channel 1 is busy, can not load task.                                                                                                                                                                                               |
| 28             | R          | 0       | CHANNEL0_F_FULL<br>task FIFO is not full.<br>0: channel 0 is ready to load task.<br>1: channel 0 is busy, can not load task.                                                                                                                                                                                               |
| 27:20          | /          | /       | /                                                                                                                                                                                                                                                                                                                          |
| 19:16          | R/W        | 0       | Channel Task Load enable<br>When set, channel load task .<br>0001: channel 0 load task enable<br>0010: channel 1 load task enable<br>0100: channel 2 load task enable<br>1000: channel 3 load task enable<br><b>Note: only when the corresponding bit is enabled, the task load signal can be loaded into the channel.</b> |
| 15             | R/W        | 0       | TASK_LOAD_RAES<br>When set, ares can load the descriptor.<br>1: load ares task<br>0: no effect                                                                                                                                                                                                                             |
| 14:11          | /          | /       | /                                                                                                                                                                                                                                                                                                                          |
| 10             | R/W        | 0       | TASK_LOAD_HASH<br>When set, hash can load the descriptor of task.<br>1: load hash task<br>0: no effect                                                                                                                                                                                                                     |
| 9:6            | /          | /       | /                                                                                                                                                                                                                                                                                                                          |
| 5              | R/W        | 0       | TASK_LOAD_ASYMM<br>When set, asymm can load the descriptor of task.<br>1: load asymm task<br>0: no effect                                                                                                                                                                                                                  |
| 4:1            | /          | /       | /                                                                                                                                                                                                                                                                                                                          |
| 0              | R/W        | 0       | TASK_LOAD_SYMM<br>When set, symm can load the descriptor of task.<br>1: load symm task<br>0: no effect                                                                                                                                                                                                                     |

#### 9.1.7.6 0x0014 Security CE Task Status Register (Default Value: 0x0000\_0000)

| Offset: 0x0014 | Register Name: CE TSRMLS |
|----------------|--------------------------|
|----------------|--------------------------|

| Bit   | Read/Write | Default/Hex | Description                                                                                                                                      |
|-------|------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:27 | /          | /           | /                                                                                                                                                |
| 26:24 | R          | 0x0         | TASK_CHAN_RAES<br>indicate which channel is run for RAES.<br>0: task channel0<br>1: task channel1<br>2: task channel2<br>3: task channel3        |
| 23:19 | /          | /           | /                                                                                                                                                |
| 18:16 | R          | 0x0         | TASK_CHAN_DIG<br>indicate which channel is run for digest.<br>0: task channel0<br>1: task channel1<br>2: task channel2<br>3: task channel3       |
| 15:11 | /          | /           | /                                                                                                                                                |
| 10:8  | R          | 0x0         | TASK_CHAN_ASYMM<br>indicate which channel is run for asymmetric.<br>0: task channel0<br>1: task channel1<br>2: task channel2<br>3: task channel3 |
| 7:3   | /          | /           | /                                                                                                                                                |
| 2:0   | R          | 0x0         | TASK_CHAN_SYMM<br>indicate which channel is run for symmetric.<br>0: task channel0<br>1: task channel1<br>2: task channel2<br>3: task channel3   |

#### 9.1.7.7 0x0018 Security CE Error Status Register (Default Value: 0x0000\_0000)



NOTE

If data length error occurs, CE needs to be reset. Because, in this case, the computation has already started. In order to ensure that the data FIFO and algorithm state machine are cleared after the error status is cleared, CE needs to be reset to ensure the normal calculation of the next task.

|                |                         |
|----------------|-------------------------|
| Offset: 0x0018 | Register Name: CE_ESR_S |
|----------------|-------------------------|

| Bit   | Read/Write | Default/Hex | Description                                                                                                                                                                                                           |
|-------|------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24 | R          | 0x0         | CHAN3_ERR_STATE<br>Error code for task channel 3<br>0x00: No error<br>0x01: algorithm not support<br>0x11: KEYSRAM access error<br>0x21: key ladder configuration error<br>0x31: data length error<br>other: reserved |
| 23:16 | R          | 0x0         | CHAN2_ERR_STATE<br>Error code for task channel 2<br>0x00: No error<br>0x01: algorithm not support<br>0x11: KEYSRAM access error<br>0x21: key ladder configuration error<br>0x31: data length error<br>other: reserved |
| 15:8  | R          | 0x0         | CHAN1_ERR_STATE<br>Error code for task channel 1<br>0x00: No error<br>0x01: algorithm not support<br>0x11: KEYSRAM access error<br>0x21: key ladder configuration error<br>0x31: data length error<br>other: reserved |
| 7:0   | R          | 0x0         | CHAN0_ERR_STATE<br>Error code for task channel 0<br>0x00: No error<br>0x01: algorithm not support<br>0x11: KEYSRAM access error<br>0x21: key ladder configuration error<br>0x31: data length error<br>other: reserved |

#### 9.1.7.8 0x0020 Security CE Symmetric algorithm DMA Current Source Address0 Register (Default Value: 0x0000\_0000)

| Offset: 0x0020 |            |             | Register Name: CE_SCSA0_S                                                                            |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                          |
| 31:0           | R          | 0x0         | SYMM_CUR_SRC_ADDR0<br>Symmetric algorithm current source address DMA reads.<br>Bit[31:0], byte addr. |

9.1.7.9 0x0024 Security CE Symmetric algorithm DMA Current Source Address1 Register (Default Value: 0x0000\_0000)

| Offset: 0x0024 |            |             | Register Name: CE_SCSA1_S                                                                             |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                           |
| 31:8           | /          | /           | /                                                                                                     |
| 7:0            | R          | 0x0         | SYMM_CUR_SRC_ADDR1<br>Symmetric algorithm current source address DMA reads.<br>Bit[39:32], byte addr. |

9.1.7.10 0x0028 Security CE Symmetric algorithm DMA Current Destination Address0 Register (Default Value: 0x0000\_0000)

| Offset: 0x0028 |            |             | Register Name: CE_SCDA0_S                                                                                  |
|----------------|------------|-------------|------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                |
| 31:0           | R          | 0x0         | SYMM_CUR_DST_ADDR0<br>Symmetric algorithm current destination address DMA writes.<br>Bit[31:0], byte addr. |

9.1.7.11 0x002C Security CE Symmetric algorithm DMA Current Destination Address1 Register (Default Value: 0x0000\_0000)

| Offset: 0x002C |            |             | Register Name: CE_SCDA1_S                                                                                   |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                 |
| 31:8           | /          | /           | /                                                                                                           |
| 7:0            | R          | 0x0         | SYMM_CUR_DST_ADDR1<br>Symmetric algorithm current destination address DMA writes.<br>Bit[39:32], byte addr. |

9.1.7.12 0x0030 Security CE Asymmetric algorithm DMA Current Source Address0 Register (Default Value: 0x0000\_0000)

| Offset: 0x0030 |            |             | Register Name: CE_ACSA0_S                                                                              |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                            |
| 31:0           | R          | 0x0         | ASYMM_CUR_SRC_ADDR0<br>Asymmetric algorithm current source address DMA reads.<br>Bit[31:0], byte addr. |

**9.1.7.13 0x0034 Security CE Asymmetric algorithm DMA Current Source Address1 Register (Default Value: 0x0000\_0000)**

| Offset: 0x0034 |            |             | Register Name: CE_ACSCA1_S                                                                              |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                             |
| 31:8           | /          | /           | /                                                                                                       |
| 7:0            | R          | 0x0         | ASYMM_CUR_SRC_ADDR1<br>Asymmetric algorithm current source address DMA reads.<br>Bit[39:32], byte addr. |

**9.1.7.14 0x0038 Security CE Asymmetric algorithm DMA Current Destination Address0 Register (Default Value: 0x0000\_0000)**

| Offset: 0x0038 |            |             | Register Name: CE_ACDA0_S                                                                                    |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                  |
| 31:0           | R          | 0x0         | ASYMM_CUR_DST_ADDR0<br>Asymmetric algorithm current destination address DMA writes.<br>Bit[31:0], byte addr. |

**9.1.7.15 0x003C Security CE Asymmetric algorithm DMA Current Destination Address1 Register (Default Value: 0x0000\_0000)**

| Offset: 0x003C |            |             | Register Name: CE_ACDA1_S                                                                                     |
|----------------|------------|-------------|---------------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                                   |
| 31:8           | /          | /           | /                                                                                                             |
| 7:0            | R          | 0x0         | ASYMM_CUR_DST_ADDR1<br>Asymmetric algorithm current destination address DMA writes.<br>Bit[39:32], byte addr. |

**9.1.7.16 0x0040 Security CE HASH algorithm DMA Current Source Address0 Register (Default Value: 0x0000\_0000)**

| Offset: 0x0040 |            |             | Register Name: CE_HCSA0_S                                                                       |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                     |
| 31:0           | R          | 0x0         | HASH_CUR_SRC_ADDR0<br>HASH algorithm current source address DMA reads.<br>Bit[31:0], byte addr. |

9.1.7.17 0x0044 Security CE HASH algorithm DMA Current Source Address1 Register (Default Value: 0x0000\_0000)

| Offset: 0x0044 |            |             | Register Name: CE_HCSA1_S                                                                        |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                      |
| 31:8           | /          | /           | /                                                                                                |
| 7:0            | R          | 0x0         | HASH_CUR_SRC_ADDR1<br>HASH algorithm current source address DMA reads.<br>Bit[39:32], byte addr. |

9.1.7.18 0x0048 Security CE HASH algorithm DMA Current Destination Address0 Register (Default Value: 0x0000\_0000)

| Offset: 0x0048 |            |             | Register Name: CE_HCDA0_S                                                                             |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                           |
| 31:0           | R          | 0x0         | HASH_CUR_DST_ADDR0<br>HASH algorithm current destination address DMA writes.<br>Bit[31:0], byte addr. |

9.1.7.19 0x004C Security CE HASH algorithm DMA Current Destination Address1 Register (Default Value: 0x0000\_0000)

| Offset: 0x004C |            |             | Register Name: CE_HCDA1_S                                                                              |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                            |
| 31:8           | /          | /           | /                                                                                                      |
| 7:0            | R          | 0x0         | HASH_CUR_DST_ADDR1<br>HASH algorithm current destination address DMA writes.<br>Bit[39:32], byte addr. |

9.1.7.20 0x0050 Security CE RAES algorithm DMA Current Source Address0 Register (Default Value: 0x0000\_0000)

| Offset: 0x0050 |            |             | Register Name: CE_XCSA0_S                                              |
|----------------|------------|-------------|------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                            |
| 31:0           | R          | 0x0         | RAES_CUR_CUR_ADDR0<br>RAES algorithm current source address DMA reads. |

9.1.7.21 0x0054 Security CE RAES algorithm DMA Current Source Address1 Register (Default Value: 0x0000\_0000)

| Offset: 0x0054 |            |             | Register Name: CE_XCSA1_S                                              |
|----------------|------------|-------------|------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                            |
| 31:8           | /          | /           | /                                                                      |
| 7:0            | R          | 0x0         | RAES_CUR_CUR_ADDR1<br>RAES algorithm current source address DMA reads. |

9.1.7.22 0x0058 Security CE RAES algorithm DMA Current Destination Address0 Register (Default Value: 0x0000\_0000)

| Offset: 0x0058 |            |             | Register Name: CE_XCDA0_S                                                                             |
|----------------|------------|-------------|-------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                           |
| 31:0           | R          | 0x0         | RAES_CUR_DST_ADDR0<br>RAES algorithm current destination address DMA writes.<br>Bit[31:0], byte addr. |

9.1.7.23 0x005C Security CE RAES algorithm DMA Current Destination Address1 Register (Default Value: 0x0000\_0000)

| Offset: 0x005C |            |             | Register Name: CE_XCDA1_S                                                                              |
|----------------|------------|-------------|--------------------------------------------------------------------------------------------------------|
| Bit            | Read/Write | Default/Hex | Description                                                                                            |
| 31:8           | /          | /           | /                                                                                                      |
| 7:0            | R          | 0x0         | RAES_CUR_DST_ADDR1<br>RAES algorithm current destination address DMA writes.<br>Bit[39:32], byte addr. |

# Appendix: Glossary

The following table contains acronyms and abbreviations used in this document.

| Term  | Meaning                                         |
|-------|-------------------------------------------------|
| A     |                                                 |
| ADC   | Analog-to-Digital Converter                     |
| AE    | Automatic Exposure                              |
| AEC   | Audio Echo Cancellation                         |
| AES   | Advanced Encryption Standard                    |
| AF    | Automatic Focus                                 |
| AGC   | Automatic Gain Control                          |
| AHB   | AMBA High-Speed Bus                             |
| ALC   | Automatic Level Control                         |
| ANR   | Active Noise Reduction                          |
| APB   | Advanced Peripheral Bus                         |
| ARM   | Advanced RISC Machine                           |
| AVS   | Audio Video Synchronization                     |
| AWB   | Automatic White Balance                         |
| B     |                                                 |
| BROM  | Boot ROM                                        |
| C     |                                                 |
| CIR   | Consumer Infrared                               |
| CMOS  | Complementary Metal-Oxide Semiconductor         |
| CP15  | Coprocessor 15                                  |
| CPU   | Central Processing Unit                         |
| CRC   | Cyclic Redundancy Check                         |
| CSI   | Camera Serial Interface                         |
| D     |                                                 |
| DDR   | Double Data Rate                                |
| DES   | Data Encryption Standard                        |
| DLL   | Delay-Locked Loop                               |
| DMA   | Direct Memory Access                            |
| DRC   | Dynamic Range Compression                       |
| DVFS  | Dynamic Voltage and Frequency Scaling           |
| E     |                                                 |
| ECC   | Error Correction Code                           |
| eFuse | Electrical Fuse, A one-time programmable memory |
| EHCI  | Enhanced Host Controller Interface              |
| eMMC  | Embedded Multi-Media Card                       |
| ESD   | Electrostatic Discharge                         |
| F     |                                                 |
| FEL   | Fireware Exchange Launch                        |

| Term     | Meaning                                   |
|----------|-------------------------------------------|
| FIFO     | First In First Out                        |
| <b>G</b> |                                           |
| GIC      | Generic Interrupt Controller              |
| GPIO     | General Purpose Input Output              |
| <b>I</b> |                                           |
| I2C      | Inter Integrated Circuit                  |
| I2S      | Inter IC Sound                            |
| ISP      | Image Signal Processor                    |
| <b>J</b> |                                           |
| JEDEC    | Joint Electron Device Engineering Council |
| JPEG     | Joint Photographic Experts Group          |
| JTAG     | Joint Test Action Group                   |
| <b>L</b> |                                           |
| LCD      | Liquid-Crystal Display                    |
| LRADC    | Low Rate Analog to Digital Converter      |
| LSB      | Least Significant Bit                     |
| LVDS     | Low Voltage Differential Signaling        |
| <b>M</b> |                                           |
| MAC      | Media Access Control                      |
| MIC      | Microphone                                |
| MIPI     | Mobile Industry Processor Interface       |
| MLC      | Multi-Level Cell                          |
| MMC      | Multimedia Card                           |
| MPEG     | Motion Pictures Expert Group              |
| MSB      | Most Significant Bit                      |
| <b>N</b> |                                           |
| N/A      | Not Application                           |
| NMI      | Non Maskable Interrupt                    |
| NTSC     | National Television Standards Committee   |
| NVM      | Non Volatile Storage Medium               |
| <b>O</b> |                                           |
| OHCI     | Open Host Controller Interface            |
| OTP      | One Time Programmable                     |
| OWA      | One Wire Audio                            |
| <b>P</b> |                                           |
| PAL      | Phase Alternating Line                    |
| PCM      | Pulse Code Modulation                     |
| PHY      | Physical Layer Controller                 |
| PID      | Packet Identifier                         |
| PLL      | Phase-Locked Loop                         |
| PPU      | Power Policy Unit                         |
| POR      | Power-On Reset                            |
| PRCM     | Power Reset Clock Management              |

| Term    | Meaning                                     |
|---------|---------------------------------------------|
| PWM     | Pulse Width Modulation                      |
| R       |                                             |
| R       | Read only/non-Write                         |
| RGB     | Read Green Blue                             |
| RGMII   | Reduced Gigabit Media Independent Interface |
| RMII    | Reduced Media Independent Interface         |
| ROM     | Read Only Memory                            |
| RSA     | Rivest-Shamir-Adleman                       |
| RTC     | Real Time Clock                             |
| S       |                                             |
| SAR     | Successive Approximation Register           |
| SD      | Secure Digital                              |
| SDIO    | Secure Digital Input Output                 |
| SDK     | Software Development Kit                    |
| SDRAM   | Synchronous Dynamic Random Access Memory    |
| SDXC    | Secure Digital Extended Capacity            |
| SLC     | Single-Level Cell                           |
| SoC     | System on Chip                              |
| SPI     | Serial Peripheral Interface                 |
| SRAM    | Static Random Access Memory                 |
| T       |                                             |
| TDES    | Triple Data Encryption Standard             |
| TWI     | Two Wire Interface                          |
| U       |                                             |
| UART    | Universal Asynchronous Receiver Transmitter |
| UDF     | Undefined                                   |
| USB DRD | Universal Serial Bus Dual Role Device       |
| UTMI    | USB2.0 Transceiver Macrocell Interface      |

---

Copyright©2023 Allwinner Technology Co.,Ltd. All Rights Reserved.

This documentation is the original work and copyrighted property of Allwinner Technology Co.,Ltd ("Allwinner"). No part of this document may be reproduced, modify, publish or transmitted in any form or by any means without prior written consent of Allwinner.

### Trademarks and Permissions

Allwinner and the Allwinner logo (incomplete enumeration) are trademarks of Allwinner Technology Co.,Ltd. All other trademarks, trade names, product or service names mentioned in this document are the property of their respective owners.

### Important Notice and Disclaimer

The purchased products, services and features are stipulated by the contract made between Allwinner Technology Co.,Ltd ("Allwinner") and the customer. All or part of the products, services and features described in this document may not be within the purchase scope or the usage scope. Please read the terms and conditions of the contract and relevant instructions carefully before using, and follow the instructions in this documentation strictly. Allwinner assumes no responsibility for the consequences of improper use (including but not limited to overvoltage, overclock, or excessive temperature).

The information in this document is provided just as a reference or typical applications, and is subject to change without notice. Every effort has been made in the preparation of this document to ensure accuracy of the contents. Allwinner is not responsible for any damage (including but not limited to indirect, incidental or special loss) or any infringement of third party rights arising from the use of this document. All statements, information, and recommendations in this document do not constitute a warranty or commitment of any kind, express or implied.

No license is granted by Allwinner herein express or implied or otherwise to any patent or intellectual property of Allwinner. Third party licences may be required to implement the solution/product. Customers shall be solely responsible to obtain all appropriately required third party licences. Allwinner shall not be liable for any licence fee or royalty due in respect of any required third party licence. Allwinner shall have no warranty, indemnity or other obligations with respect to third party licences.



Copyright © 2023 Allwinner Technology Co., Ltd. All Rights Reserved.

Allwinner Technology Co., Ltd.  
No.9 Technology Road 2, High-Tech Zone,  
Zhuhai, Guangdong Province, China

Contact US:  
[Service@allwinnertech.com](mailto:Service@allwinnertech.com)  
[www.allwinnertech.com](http://www.allwinnertech.com)