



# MT7682 Reference Manual

Version: 1.0

Release date: 5 May 2017

---

© 2016 - 2017 MediaTek Inc.

This document contains information that is proprietary to MediaTek Inc. ("MediaTek") and/or its licensor(s). MediaTek cannot grant you permission for any material that is owned by third parties. You may only use or reproduce this document if you have agreed to and been bound by the applicable license agreement with MediaTek ("License Agreement") and been granted explicit permission within the License Agreement ("Permitted User"). If you are not a Permitted User, please cease any access or use of this document immediately. Any unauthorized use, reproduction or disclosure of this document in whole or in part is strictly prohibited. THIS DOCUMENT IS PROVIDED ON AN "AS-IS" BASIS ONLY. MEDIATEK EXPRESSLY DISCLAIMS ANY AND ALL WARRANTIES OF ANY KIND AND SHALL IN NO EVENT BE LIABLE FOR ANY CLAIMS RELATING TO OR ARISING OUT OF THIS DOCUMENT OR ANY USE OR INABILITY TO USE THEREOF. Specifications contained herein are subject to change without notice.

## Document Revision History

---

| Revision | Date       | Description      |
|----------|------------|------------------|
| 1.0      | 5 May 2017 | Initial version. |

## Table of Contents

---

|           |                                                            |            |
|-----------|------------------------------------------------------------|------------|
| <b>1.</b> | <b>Documentation General Conventions .....</b>             | <b>1</b>   |
| 1.1.      | Abbreviations for control modules.....                     | 1          |
| 1.2.      | Abbreviations for registers .....                          | 2          |
| <b>2.</b> | <b>Bus Architecture and Memory Map .....</b>               | <b>3</b>   |
| <b>3.</b> | <b>External Interrupt Controller .....</b>                 | <b>7</b>   |
| 3.1.      | Overview.....                                              | 7          |
| 3.2.      | Features .....                                             | 7          |
| 3.3.      | Block diagram .....                                        | 7          |
| 3.4.      | Wakeup event management .....                              | 7          |
| 3.5.      | Functions .....                                            | 8          |
| 3.6.      | External interrupt or event line mapping .....             | 9          |
| 3.7.      | Register mapping.....                                      | 10         |
| <b>4.</b> | <b>Direct Memory Access .....</b>                          | <b>20</b>  |
| 4.1.      | Overview.....                                              | 20         |
| 4.2.      | Features .....                                             | 20         |
| 4.3.      | Functions .....                                            | 21         |
| 4.4.      | Application and programming sequence.....                  | 23         |
| 4.5.      | Register mapping.....                                      | 24         |
| <b>5.</b> | <b>Universal Asynchronous Receiver/Transmitter .....</b>   | <b>52</b>  |
| 5.1.      | Overview.....                                              | 52         |
| 5.2.      | Features .....                                             | 52         |
| 5.3.      | Block diagram .....                                        | 52         |
| 5.4.      | Functions .....                                            | 53         |
| 5.5.      | Register mapping.....                                      | 55         |
| <b>6.</b> | <b>Serial Peripheral Interface Master Controller .....</b> | <b>70</b>  |
| 6.1.      | Features .....                                             | 70         |
| 6.2.      | Block diagram .....                                        | 72         |
| 6.3.      | Functions .....                                            | 72         |
| 6.4.      | Register mapping.....                                      | 74         |
| <b>7.</b> | <b>Serial Peripheral Interface Slave Controller .....</b>  | <b>83</b>  |
| 7.1.      | Features .....                                             | 83         |
| 7.2.      | Block diagram .....                                        | 85         |
| 7.3.      | Functions .....                                            | 85         |
| 7.4.      | Register mapping.....                                      | 89         |
| <b>8.</b> | <b>Inter-Integrated Circuit Controller .....</b>           | <b>97</b>  |
| 8.1.      | Overview.....                                              | 97         |
| 8.2.      | Features .....                                             | 97         |
| 8.3.      | Block diagram .....                                        | 97         |
| 8.4.      | Functions .....                                            | 98         |
| 8.5.      | Programming guide .....                                    | 100        |
| 8.6.      | Manual and DMA transfer modes for I2C controller .....     | 101        |
| 8.7.      | Register mapping.....                                      | 101        |
| <b>9.</b> | <b>SD/SDIO Card Controller .....</b>                       | <b>114</b> |
| 9.1.      | Overview.....                                              | 114        |
| 9.2.      | Features .....                                             | 114        |
| 9.3.      | Block diagram .....                                        | 115        |

|            |                                              |            |
|------------|----------------------------------------------|------------|
| 9.4.       | Functions .....                              | 115        |
| 9.5.       | Programming sequence.....                    | 116        |
| 9.6.       | Register mapping.....                        | 116        |
| <b>10.</b> | <b>I2S0.....</b>                             | <b>148</b> |
| 10.1.      | Overview.....                                | 148        |
| 10.2.      | IO interface .....                           | 148        |
| 10.3.      | I2S OUT and I2S IN .....                     | 150        |
| 10.4.      | DL FIFO and UL FIFO .....                    | 151        |
| 10.5.      | Data format of FIFO .....                    | 151        |
| 10.6.      | Programming guide .....                      | 152        |
| 10.7.      | Register mapping.....                        | 155        |
| <b>11.</b> | <b>I2S1.....</b>                             | <b>163</b> |
| 11.1.      | Overview.....                                | 163        |
| 11.2.      | IO interface .....                           | 163        |
| 11.3.      | I2S OUT and I2S IN .....                     | 164        |
| 11.4.      | DL FIFO and UL FIFO .....                    | 165        |
| 11.5.      | Data format of FIFO .....                    | 165        |
| 11.6.      | Programming guide .....                      | 166        |
| 11.7.      | Register mapping.....                        | 168        |
| <b>12.</b> | <b>I2S0 and I2S1 Audio PLL Settings.....</b> | <b>179</b> |
| 12.1.      | XPLL block diagram .....                     | 179        |
| 12.2.      | Fractional-N PLL power on sequence .....     | 179        |
| 12.3.      | XPLL frequency setting (Integer) .....       | 180        |
| 12.4.      | DDS PCW setting.....                         | 181        |
| 12.5.      | XPLL frequency change sequence.....          | 181        |
| 12.6.      | XPLL turn on programming sequence.....       | 181        |
| 12.7.      | XPLL turn off programming sequence .....     | 185        |
| <b>13.</b> | <b>SDIO .....</b>                            | <b>186</b> |
| 13.1.      | Overview.....                                | 186        |
| 13.2.      | Features .....                               | 186        |
| 13.3.      | Block diagram .....                          | 187        |
| 13.4.      | Functions .....                              | 187        |
| 13.5.      | Register mapping.....                        | 190        |
| <b>14.</b> | <b>General Purpose Timer .....</b>           | <b>329</b> |
| 14.1.      | Overview.....                                | 329        |
| 14.2.      | Features .....                               | 329        |
| 14.3.      | Limitations .....                            | 329        |
| 14.4.      | Block diagram .....                          | 330        |
| 14.5.      | Functions .....                              | 330        |
| 14.6.      | Programming sequence.....                    | 330        |
| 14.7.      | Register mapping.....                        | 331        |
| <b>15.</b> | <b>Pulse Width Modulation .....</b>          | <b>352</b> |
| 15.1.      | Overview.....                                | 352        |
| 15.2.      | Features .....                               | 352        |
| 15.3.      | Block diagram .....                          | 352        |
| 15.4.      | Functions .....                              | 353        |
| 15.5.      | Register mapping.....                        | 354        |
| <b>16.</b> | <b>Cortex-M4 L1 Cache Controller .....</b>   | <b>357</b> |
| 16.1.      | Overview.....                                | 357        |
| 16.2.      | Cache optimization.....                      | 359        |
| 16.3.      | Register mapping.....                        | 364        |

|                                                    |            |
|----------------------------------------------------|------------|
| 16.4. Cacheable region controller .....            | 370        |
| 16.5. Remapping.....                               | 373        |
| <b>17. Auxiliary ADC Unit .....</b>                | <b>377</b> |
| 17.1. Features .....                               | 377        |
| 17.2. Block diagram .....                          | 377        |
| 17.3. Functions .....                              | 378        |
| 17.4. Programming sequence.....                    | 378        |
| 17.5. Register mapping.....                        | 380        |
| <b>18. Reset Generation Unit .....</b>             | <b>384</b> |
| 18.1. Features .....                               | 384        |
| 18.2. Block diagram .....                          | 384        |
| 18.3. WDT timeout and interval source .....        | 384        |
| 18.4. Register mapping.....                        | 385        |
| <b>19. True Random Number Generator .....</b>      | <b>396</b> |
| 19.1. Overview.....                                | 396        |
| 19.2. Features .....                               | 396        |
| 19.3. Block diagram .....                          | 396        |
| 19.4. Function description.....                    | 397        |
| 19.5. Programming sequence.....                    | 398        |
| 19.6. Register mapping.....                        | 399        |
| <b>20. Real Time Clock (RTC) .....</b>             | <b>403</b> |
| 20.1. Features .....                               | 403        |
| 20.2. Block diagram .....                          | 403        |
| 20.3. Functions .....                              | 404        |
| 20.4. Programming sequence.....                    | 404        |
| 20.5. Register mapping.....                        | 404        |
| <b>21. General Purpose Inputs/Outputs.....</b>     | <b>415</b> |
| 21.1. Overview.....                                | 415        |
| 21.2. IO pull up or down control truth table ..... | 415        |
| 21.3. Register mapping.....                        | 417        |
| <b>22. Clock Configuration .....</b>               | <b>472</b> |
| 22.1. Clock configuration programming guide .....  | 472        |
| 22.2. Register mapping.....                        | 478        |

## Lists of Tables and Figures

---

|                                                                                           |     |
|-------------------------------------------------------------------------------------------|-----|
| Table 2.1-1. MT7682 bus connection.....                                                   | 3   |
| Table 2.1-2. Top view memory map .....                                                    | 3   |
| Table 2.1-3. Always-on domain peripherals .....                                           | 4   |
| Table 2.1-4. Power-down domain peripherals.....                                           | 5   |
| Table 3.6-1. External interrupt sources.....                                              | 9   |
| Table 4.4-1. Virtual FIFO access ports .....                                              | 23  |
| Table 5.5-1. SPI master controller interface .....                                        | 70  |
| Table 6.4-1. SPI slave controller interface .....                                         | 83  |
| Table 7.3-1. SPI slave controller interface .....                                         | 85  |
| Table 7.3-2. SPI slave status description (use RS command to poll SPI slave status) ..... | 87  |
| Table 9.4-1. Sharing of pins for SD memory card controller.....                           | 115 |
| Table 9.6-1. MSDC register definition .....                                               | 116 |
| Table 10.2-1. I2S mode interface – master mode.....                                       | 148 |
| Table 10.2-2. I2S mode interface – slave mode .....                                       | 149 |
| Table 10.2-3. TDM mode interface – master mode .....                                      | 149 |
| Table 10.2-4. TDM mode interface – slave mode .....                                       | 149 |
| Table 10.2-5. Relationship between MCLK and sample rate .....                             | 149 |
| Table 10.3-1. Down rate example for slave mode .....                                      | 150 |
| Table 10.5-1. 16bits I2S data format of FIFO .....                                        | 151 |
| Table 10.5-2. 16bits TDM 4 channel data format of FIFO .....                              | 151 |
| Table 11.2-1. I2S mode interface – master mode.....                                       | 163 |
| Table 11.2-2. I2S mode interface – slave mode .....                                       | 164 |
| Table 11.2-3. Relationship between MCLK and sample rate .....                             | 164 |
| Table 11.5-1. 16bits I2S data format of FIFO .....                                        | 165 |
| Table 11.5-2. 24bits I2S data format of FIFO .....                                        | 166 |
| Table 13.4-1. SDIO pin definitions.....                                                   | 187 |
| Table 13.4-2. Bus signal voltage.....                                                     | 188 |
| Table 13.4-3. Bus timing parameter values (default).....                                  | 189 |
| Table 13.4-4. High-speed timing parameter values .....                                    | 190 |
| Table 14.5-1. GPT operation modes .....                                                   | 330 |
| Table 16.1-1. TCM address spaces for different cache size settings.....                   | 358 |
| Table 16.2-1. Write-back mode cache read or write operations .....                        | 363 |
| Table 16.2-2. Write-through mode cache R/W action summary .....                           | 364 |
| Table 16.4-1. Cacheable attribute bit encoding.....                                       | 371 |
| Table 16.5-1. Region size and bit encoding.....                                           | 375 |
| Table 17.3-1. AUXADC channel description .....                                            | 378 |
| Table 21.2-1. GPIO IO structure .....                                                     | 415 |
| Table 21.2-2. GPIO versus IO type mapping .....                                           | 416 |
| Table 21.2-3. IO type 1 - pull up/down control.....                                       | 416 |
| Table 21.2-4. IO type 2 - pull up/down control.....                                       | 416 |

|                                                                                             |     |
|---------------------------------------------------------------------------------------------|-----|
| Table 21.2-5. IO type 3 - pull up/down control.....                                         | 417 |
| Table 22.1-1. Clock switch.....                                                             | 473 |
| Table 22.1-2. Relationship between XO_PDN_CONDO bit number and configuration register ..... | 474 |
| Table 22.1-3. Clock multiplexer switch method of HF_FSYS_CK.....                            | 475 |
| Table 22.1-4. Relationship between PDN_CONDO bit number and configuration register .....    | 475 |
| Table 22.1-5. Clock multiplexer switch method of HF_FSFC_CK .....                           | 476 |
| Table 22.1-6. Clock multiplexer switch method of F_FSDIOMST_CK.....                         | 476 |
| Table 22.1-7. Clock multiplexer switch method of F_FSDIOMST_CK.....                         | 477 |
| Table 22.1-8. Clock multiplexer switch method of F_FSDIOMST_CK.....                         | 477 |
| Table 22.1-9. Clock multiplexer switch method of F_FSDIOMST_CK.....                         | 478 |
| <br>Figure 3.3-1. EINT block diagram .....                                                  | 7   |
| Figure 4.1-1. Variety data paths of DMA transfers .....                                     | 20  |
| Figure 4.2-1. DMA block diagram.....                                                        | 21  |
| Figure 4.3-1. Ring buffer and double buffer memory data movement .....                      | 22  |
| Figure 4.3-2. Unaligned word accesses.....                                                  | 22  |
| Figure 4.3-3. Virtual FIFO DMA .....                                                        | 23  |
| Figure 5.3-1. UART block diagram.....                                                       | 53  |
| Figure 5.4-1. UART data format .....                                                        | 54  |
| Figure 5.5-1. Pin connection between SPI master and SPI slave .....                         | 70  |
| Figure 6.1-1. SPI transmission formats .....                                                | 71  |
| Figure 6.1-2. Operation flow with or without PAUSE mode .....                               | 71  |
| Figure 6.1-3. CS de-assert mode .....                                                       | 71  |
| Figure 6.1-4. SPI master controller delay sample .....                                      | 72  |
| Figure 6.2-1. Block diagram of SPI master controller.....                                   | 72  |
| Figure 6.3-1. SPI master single mode.....                                                   | 73  |
| Figure 6.3-2. SPI master dual mode write data.....                                          | 73  |
| Figure 6.3-3. SPI master dual mode read data.....                                           | 73  |
| Figure 6.3-4. SPI master quad mode write data .....                                         | 73  |
| Figure 6.3-5. SPI master quad mode read data.....                                           | 74  |
| Figure 6.4-1. Pin connection between SPI master and SPI slave .....                         | 83  |
| Figure 7.1-1. SPI transmission formats .....                                                | 84  |
| Figure 7.1-2. SPI slave controller early transmit .....                                     | 84  |
| Figure 7.2-1. Block diagram of SPI slave controller .....                                   | 85  |
| Figure 7.3-1. SPI slave controller commands waveform.....                                   | 86  |
| Figure 7.3-2. Config read/write (CR/CW) command format.....                                 | 86  |
| Figure 7.3-3. SPI slave control flow diagram.....                                           | 87  |
| Figure 7.3-4. SPI slave single mode write data .....                                        | 88  |
| Figure 7.3-5. SPI slave single mode read data.....                                          | 88  |
| Figure 7.3-6. SPI slave dual mode write data.....                                           | 88  |
| Figure 7.3-7. SPI slave dual mode read data.....                                            | 88  |
| Figure 7.3-8. SPI slave quad mode write data.....                                           | 89  |
| Figure 7.3-9. SPI slave quad mode read data.....                                            | 89  |
| Figure 8.3-1. I2C block diagram.....                                                        | 98  |

|                                                                                         |     |
|-----------------------------------------------------------------------------------------|-----|
| Figure 8.4-1. I2C single transfer single byte access.....                               | 98  |
| Figure 8.4-2. I2C single transfer multi byte access.....                                | 99  |
| Figure 8.4-3. I2C multi transfer multi byte access .....                                | 99  |
| Figure 8.4-4. I2C multi transfer multi byte access with RS.....                         | 99  |
| Figure 8.4-5. I2C multi transfer multi byte access with direction-change function ..... | 100 |
| Figure 8.5-1. I2C transfer format programming guide.....                                | 100 |
| Figure 8.5-2. I2C timing format programming guide .....                                 | 101 |
| Figure 9.3-1. MSDC block diagram .....                                                  | 115 |
| Figure 10.1-1. I2S block diagram.....                                                   | 148 |
| Figure 10.3-1. I2S protocol waveform.....                                               | 150 |
| Figure 10.3-2. Sample m of TDM32 with nT delay .....                                    | 150 |
| Figure 10.3-3. Sample m of TDM32 with nT delay and bclk inverse .....                   | 151 |
| Figure 10.3-4. Sample m of TDM64 with nT delay .....                                    | 151 |
| Figure 11.1-1. I2S block diagram.....                                                   | 163 |
| Figure 11.3-1. I2S protocol waveform.....                                               | 165 |
| Figure 12.1-1. XPLL block diagram .....                                                 | 179 |
| Figure 12.2-1. Fractional-N PLL power on sequence .....                                 | 180 |
| Figure 12.4-1. DDS PCW settings .....                                                   | 181 |
| Figure 12.5-1. XPLL frequency change sequence .....                                     | 181 |
| Figure 13.3-1. SDIO controller block diagram .....                                      | 187 |
| Figure 13.4-1. Signal connections to 4-bit SDIO cards .....                             | 187 |
| Figure 13.4-2. Bus signal levels .....                                                  | 188 |
| Figure 13.4-3. Bus timing diagram (default) .....                                       | 189 |
| Figure 13.4-4. High-speed timing diagram.....                                           | 190 |
| Figure 14.4-1. GPT block diagram .....                                                  | 330 |
| Figure 15.1-1. PWM waveform .....                                                       | 352 |
| Figure 15.3-1. PWM block diagram.....                                                   | 353 |
| Figure 15.4-1. PWM waveform with register values.....                                   | 354 |
| Figure 16.1-1. MCU, Cache, TCM and AHB bus connectivity .....                           | 357 |
| Figure 16.1-2. Cache size and TCM settings.....                                         | 358 |
| Figure 16.2-1. Cache lookup for 4-way set associative .....                             | 360 |
| Figure 16.2-2. Cache miss/refill criteria .....                                         | 362 |
| Figure 16.4-1. Cacheable setting example .....                                          | 370 |
| Figure 16.5-1. Example settings of cache remapping .....                                | 373 |
| Figure 16.5-1. SAR ADC waveform .....                                                   | 377 |
| Figure 17.2-1. AUXADC block diagram.....                                                | 378 |
| Figure 17.4-1. Immediate mode programming sequence .....                                | 379 |
| Figure 18.2-1. Block diagram of RGU .....                                               | 384 |
| Figure 18.3-1. WDT timeout length and interval time .....                               | 385 |
| Figure 19.3-1. TRNG block diagram .....                                                 | 396 |
| Figure 19.3-2. Ring Oscillator .....                                                    | 397 |
| Figure 19.3-3. Inverter Core .....                                                      | 397 |
| Figure 19.4-1. TRNG operation flow .....                                                | 398 |
| Figure 20.2-1. RTC block diagram .....                                                  | 404 |

|                                                |     |
|------------------------------------------------|-----|
| Figure 21.1-1. GPIO block diagram .....        | 415 |
| Figure 22.1-1. Clock source architecture ..... | 473 |

## 1. Documentation General Conventions

### 1.1. Abbreviations for control modules

| Abbreviation | Full name                                     |
|--------------|-----------------------------------------------|
| EINT         | External interrupt controller                 |
| DMA          | Direct memory access                          |
| UART         | Universal asynchronous receiver transmitter   |
| SPI master   | Serial peripheral interface master controller |
| SPI slave    | Serial peripheral interface slave controller  |
| I2C          | Inter-integrated circuit interface            |
| MSDC         | SD memory card controller                     |
| I2S0         | Inter-IC sound channel 0                      |
| XPLL         | Audio phase-locked loop                       |
| SDIO         | Secure digital input/output                   |
| I2S1         | Inter-IC sound channel 1                      |
| GPT          | General purpose timer                         |
| PWM          | Pulse width modulation                        |
| AUXADC       | Auxiliary ADC                                 |
| RGU          | Reset generation unit                         |
| RTC          | Real-time clock                               |
| TRNG         | True random number generator                  |
| GPIO         | General purpose input/output                  |

## 1.2. Abbreviations for registers

| Abbreviation | Full name                |
|--------------|--------------------------|
| RW           | Read and write           |
| RO           | Read only                |
| WO           | Write only               |
| RC           | Read 1 to clear          |
| WC           | Write 1 to clear         |
| RWC          | Read or write 1 to clear |
| FM           | Frequency measurement    |
| FRC          | Free running counter     |

## 2. Bus Architecture and Memory Map

---

MediaTek MT7682 adopts 32-bit multi-AHB matrix to provide low power, fast and flexible data operation for IoT and Wearables applications. Table 2.1-1 shows the interconnections between bus masters (Cortex-M4, four SPI masters, SPI slave, debug system, Wi-Fi connectivity system, crypto engine and direct memory access (DMA) controller) and slaves (AO APB peripherals, PD APB peripherals, TCM, SFC, EMI, SYSRAM, RTC RAM, Wi-Fi connectivity system).

*Table 2.1-1. MT7682 bus connection*

| Master<br>Slave \             | ARM<br>Cortex-M4 | PD DMA | SPM | SPI Master | SPI Slave | SDIO<br>Master | SDIO<br>Slave | Crypto<br>Engine | CONN SYS<br>Master |
|-------------------------------|------------------|--------|-----|------------|-----------|----------------|---------------|------------------|--------------------|
| <b>AO APB<br/>Peripherals</b> | •                | •      | •   |            |           |                |               | •                |                    |
| <b>PD APB<br/>Peripherals</b> | •                | •      | •   |            |           |                |               | •                |                    |
| <b>TCM</b>                    | •                | •      | •   |            |           |                |               | •                |                    |
| <b>EMI</b>                    | •                | •      | •   | •          | •         | •              | •             | •                | •                  |
| <b>SFC</b>                    | •                | •      | •   |            |           |                |               | •                |                    |
| <b>SYSRAM</b>                 | •                | •      | •   | •          | •         | •              | •             | •                | •                  |
| <b>RTC SRAM</b>               | •                | •      | •   | •          | •         | •              | •             | •                | •                  |
| <b>CONN SYS</b>               | •                | •      | •   |            |           |                |               | •                |                    |

*Table 2.1-2. Top view memory map*

| Start Address | End Address | Module              |
|---------------|-------------|---------------------|
| 0x0000_0000   | 0x03FF_FFFF | EMI                 |
| 0x0400_0000   | 0x0400_7FFF | Cortex-M4 TCM/cache |
| 0x0400_8000   | 0x0401_7FFF | Cortex-M4 TCM       |
| 0x0410_0000   | 0x041F_FFFF | Boot ROM            |
| 0x0420_0000   | 0x0425_FFFF | SYSRAM              |
| 0x0430_0000   | 0x043F_FFFF | Retention SRAM      |

| Start Address | End Address | Module                                      |
|---------------|-------------|---------------------------------------------|
| 0x0440_0000   | 0x044F_FFFF | Wi-Fi ROM                                   |
| 0x0800_0000   | 0x0FFF_FFFF | SFC                                         |
| 0xA000_0000   | 0xA0FF_FFFF | PD APB peripherals                          |
| 0xA100_0000   | 0xA1FF_FFFF | PD AHB peripherals                          |
| 0xA200_0000   | 0xA20F_FFFF | AO APB peripherals                          |
| 0xC000_0000   | 0xCFFF_FFFF | CONNNSYS                                    |
| 0xE000_0000   | 0xE003_FFFF | Cortex-M4 private peripheral bus - internal |
| 0xE004_0000   | 0xE00F_FFFF | Cortex-M4 private peripheral bus - external |
| 0xE010_0000   | 0xE01F_FFFF | Cortex-M4 peripheral                        |

**Table 2.1-3. Always-on domain peripherals**

| Start Address | Module                           | Bus Interface | Notes                                |
|---------------|----------------------------------|---------------|--------------------------------------|
| A200_0000     | VERSION_CTRL                     | APB           | Mapped to 0x8000_0000                |
| A201_0000     | Configuration registers          | APB           | Clock, power down, version and reset |
| A202_0000     | BBPLL control                    | APB           |                                      |
| A203_0000     | XPLL control                     | APB           |                                      |
| A204_0000     | Analog chip interface controller | APB           | PLL, CLKSQ, FH, CLKSW and SIMLS      |
| A205_0000     | Top clock control                | APB           | DCM, CG                              |
| A206_0000     | RF XTAL control                  | APB           |                                      |
| A207_0000     | PMU configuration                | APB           |                                      |
| A208_0000     | Real-time clock                  | APB           |                                      |
| A209_0000     | Reset generation unit            | APB           |                                      |
| A20A_0000     | eFuse                            | APB           |                                      |
| A20B_0000     | General purpose inputs/outputs   | APB           |                                      |
| A20C_0000     | IO configuration 0               | APB           |                                      |
| A20D_0000     | IO configuration 1               | APB           |                                      |

| Start Address | Module                           | Bus Interface | Notes        |
|---------------|----------------------------------|---------------|--------------|
| A20E_0000     | SEJ                              | APB           |              |
| A20F_0000     | SPM                              | APB           |              |
| A210_0000     | Interrupt controller (EINT)      | APB           |              |
| A211_0000     | GP Timer                         | APB           |              |
| A212_0000     | Pulse width modulation outputs 0 | APB           |              |
| A213_0000     | Pulse width modulation outputs 1 | APB           |              |
| A214_0000     | Pulse width modulation outputs 2 | APB           |              |
| A215_0000     | Pulse width modulation outputs 3 | APB           |              |
| A216_0000     | Pulse width modulation outputs 4 | APB           |              |
| A217_0000     | Pulse width modulation outputs 5 | APB           |              |
| A21D_0000     | Configuration Registers          | APB           | Clock, 96MHz |
| A21E_0000     | CM4_CFG_PRIVATE                  | APB           |              |
| A21F_0000     | INFRA BUS configuration          | APB           |              |

**Table 2.1-4. Power-down domain peripherals**

| Start Address | Module                    | Bus Interface |
|---------------|---------------------------|---------------|
| A001_0000     | TRNG                      | APB           |
| A002_0000     | DMA controller            | APB           |
| A003_0000     | INFRA MBIST configuration | APB           |
| A004_0000     | Serial flash              | APB           |
| A005_0000     | External memory interface | APB           |
| A006_0000     | Crypto Engine             | APB           |
| A007_0000     | ADUIO                     | APB           |
| A008_0000     | ASYS                      | APB           |
| A00A_0000     | SPI_MASTER 0              | APB           |
| A00B_0000     | SPI_SLAVE                 | APB           |
| A00C_0000     | UART 0                    | APB           |

| Start Address | Module             | Bus Interface |
|---------------|--------------------|---------------|
| A00D_0000     | UART 1             | APB           |
| A00E_0000     | UART 2             | APB           |
| A010_0000     | I2C_0              | APB           |
| A011_0000     | I2C_1              | APB           |
| A012_0000     | Auxiliary ADC Unit | APB           |
| A100_0000     | PD DMA             | AHB           |
| A101_0000     | ADUIO              | AHB           |
| A102_0000     | ASYS               | AHB           |
| A103_0000     | SDIO Master        | AHB           |
| A104_0000     | SDIO Slave         | AHB           |

### 3. External Interrupt Controller

#### 3.1. Overview

The external interrupt controller (EINT) consists of up to 32 edge detectors to generate event or interrupt requests. Each input line can be independently configured to select type (event or interrupt) and the corresponding trigger event (rising edge or falling edge or both or level). Each line can also be masked independently. A pending register maintains the status line of the interrupt requests.

#### 3.2. Features

The EINT controller offers the following main features:

- Independent trigger and mask on each interrupt/event line.
- Dedicated status bit for each interrupt line.
- Generation of up to 32 software interrupt/event requests.

#### 3.3. Block diagram

Figure 3.3-1 shows the block diagram of the EINT controller.



*Figure 3.3-1. EINT block diagram*

#### 3.4. Wakeup event management

MT7682 is able to handle external or internal events in order to wake up the core (WFI). The wakeup event can be generated by:

- Configuring an external or internal EINT line in event mode. When the CPU resumes from WFI, it is not necessary to clear the peripheral interrupt pending bit or the NVIC IRQ channel pending bit as the pending bit corresponding to the event line is not set.

## 3.5. Functions

To generate an interrupt, an interrupt line should be configured and enabled. Program two trigger registers with desired edge detection (EINT\_SENS, EINT\_DUALEDGE\_SENS, EINT\_POL) and enable an interrupt request by writing “1” to the corresponding bit in the interrupt mask clear register (EINT\_MASK\_CLR). When the selected trigger occurs on the external interrupt line, an interrupt request is generated. The pending bit corresponding to the interrupt line is also set in the EINT interrupt status register (EINT\_STA). This request is reset by writing “1” in the EINT interrupt acknowledge register (EINT\_INTACK).

To generate the event, the event line should be configured and enabled. Program three trigger registers with desired edge detection (EINT\_SENS, EINT\_DUALEDGE\_SENS, EINT\_POL) and enable the event request by writing “1” to the corresponding bit in the event mask clear register (EINT\_WACKUP\_MASK\_CLR) and interrupt mask clear register (EINT\_MASK\_CLR). When the selected trigger occurs on the event line, an event request is generated. The pending bit corresponding to the event line is also set in the EINT interrupt status register (EINT\_STA). This request is reset by writing “1” in the EINT interrupt acknowledge register (EINT\_INTACK).

### 3.5.1. Hardware interrupt

To configure the 32 lines as interrupt sources:

- Configure the mask bits of the 32 interrupt lines (EINT\_MASK\_CLR).
- Configure the trigger selection bits of the interrupt lines (EINT\_SENS\_SET, EINT\_SENS\_CLR, EINT\_DUALEDGE\_SENS\_SET, EINT\_DUALEDGE\_SENS\_CLR, EINT\_POL\_SET, EINT\_POL\_CLR).

| Trigger Type \ Register setting | EINT_SENS_SET | EINT_SENS_CLR | EINT_DUALEDGE_SENS_SET | EINT_DUALEDGE_SENS_CLR | EINT_POL_SET | EINT_POL_CLR |
|---------------------------------|---------------|---------------|------------------------|------------------------|--------------|--------------|
| ↑ (Rising Edge)                 | 0             | 1             | 0                      | 1                      | 1            | 0            |
| ↓ (Falling Edge)                | 0             | 1             | 0                      | 1                      | 0            | 1            |
| ↑ ↓ (Dual Edge)                 | 0             | 1             | 1                      | 0                      | Don't care   | Don't care   |
| / (High Level)                  | 1             | 0             | Don't care             | Don't care             | 1            | 0            |
| \ (Low Level)                   | 1             | 0             | Don't care             | Don't care             | 0            | 1            |

- Configure the enable and mask bits that control the NVIC IRQ channel mapped to the external interrupt controller (EINT) so that an interrupt coming from one of the 32 lines can be correctly acknowledged.

### 3.5.2. Hardware events

To configure the 32 lines as event sources:

- Configure the mask bits of the 32 event lines (EINT\_WACKUP\_MASK\_CLR and EINT\_MASK\_CLR).
- Configure the trigger selection bits of the event lines (EINT\_SENS\_SET, EINT\_SENS\_CLR, EINT\_DUALEDGE\_SENS\_SET, EINT\_DUALEDGE\_SENS\_CLR, EINT\_POL\_SET, EINT\_POL\_CLR).

### 3.5.3. Software interrupt

The 32 lines can be configured as software interrupt lines. To generate a software interrupt:

- Configure the mask bits of the 32 interrupt lines (EINT\_MASK\_CLR).
- Set the required bit in the software interrupt register (EINT\_SOFT\_SET).

### 3.6. External interrupt or event line mapping

Up to 21 GPIOs are connected to the 20 external interrupt/eve, as shown in Table 3.6-1.

*Table 3.6-1. External interrupt sources*

| EINT   | Source pin                                                                                                       |
|--------|------------------------------------------------------------------------------------------------------------------|
| EINT0  | PAD_GPIO_0 if ( <a href="#">GPIO0_MODE==1</a> )                                                                  |
| EINT1  | PAD_GPIO_1 if ( <a href="#">GPIO1_MODE==1</a> )                                                                  |
| EINT2  | PAD_GPIO_2 if ( <a href="#">GPIO2_MODE==1</a> )                                                                  |
| EINT3  | PAD_GPIO_3 if ( <a href="#">GPIO3_MODE==1</a> )                                                                  |
| EINT4  | PAD_GPIO_4 if ( <a href="#">GPIO4_MODE==3</a> )                                                                  |
| EINT5  | PAD_GPIO_5 if ( <a href="#">GPIO5_MODE==3</a> )                                                                  |
| EINT6  | PAD_GPIO_6 if ( <a href="#">GPIO6_MODE==3</a> )                                                                  |
| EINT7  | PAD_GPIO_7 if ( <a href="#">GPIO7_MODE==3</a> )                                                                  |
| EINT8  | PAD_GPIO_8 if ( <a href="#">GPIO8_MODE==3</a> )                                                                  |
| EINT9  | PAD_GPIO_9 if ( <a href="#">GPIO9_MODE==3</a> )                                                                  |
| EINT10 | PAD_GPIO_10 if ( <a href="#">GPIO10_MODE==1</a> )                                                                |
| EINT11 | PAD_GPIO_11 if ( <a href="#">GPIO11_MODE==1</a> )                                                                |
| EINT12 | PAD_GPIO_12 if ( <a href="#">GPIO12_MODE==6</a> )                                                                |
| EINT13 | PAD_GPIO_13 if ( <a href="#">GPIO13_MODE==8</a> )                                                                |
| EINT14 | PAD_GPIO_14 if ( <a href="#">GPIO14_MODE==8</a> )                                                                |
| EINT15 | PAD_GPIO_15 if ( <a href="#">GPIO15_MODE==8</a> )                                                                |
| EINT16 | PAD_GPIO_16 if ( <a href="#">GPIO16_MODE==8</a> )                                                                |
| EINT17 | PAD_GPIO_17 if ( <a href="#">GPIO17_MODE==8</a> )                                                                |
| EINT18 | PAD_GPIO_18 if ( <a href="#">GPIO18_MODE==8</a> )                                                                |
| EINT19 | PAD_GPIO_19 if ( <a href="#">GPIO19_MODE==2</a> )<br>PAD_GPIO_21 if ( <a href="#">GPIO19_MODE==2</a> ) in MT5932 |
| EINT20 | PAD_GPIO_20 if ( <a href="#">GPIO20_MODE==2</a> )<br>PAD_GPIO_22 if ( <a href="#">GPIO20_MODE==2</a> ) in MT5932 |
| EINT21 | uart0_rxd                                                                                                        |
| EINT22 | uart1_rxd                                                                                                        |
| EINT23 | uart2_rxd                                                                                                        |
| EINT24 | rtc_event_b                                                                                                      |
| EINT25 | conn2ap_hif_int_b                                                                                                |
| EINT26 | conn2ap_pse_irq_b                                                                                                |
| EINT27 | conn2ap_wdt_irq_b                                                                                                |
| EINT28 | conn2ap_mac_irq_b                                                                                                |
| EINT29 | pmu_int_b                                                                                                        |
| EINT30 |                                                                                                                  |
| EINT31 |                                                                                                                  |

### 3.7. Register mapping

Module name: EINT Base address: (+A2100000h)

| Address             | Name                          | Width | Register Function                         |
|---------------------|-------------------------------|-------|-------------------------------------------|
| A2100300            | <u>EINT STA</u>               | 32    | EINT interrupt status register            |
| A2100308            | <u>EINT INTACK</u>            | 32    | EINT interrupt acknowledge register       |
| A2100310            | <u>EINT EEVT</u>              | 32    | EINT wakeup event_b status register       |
| A2100320            | <u>EINT MASK</u>              | 32    | EINT interrupt mask register              |
| A2100328            | <u>EINT MASK SET</u>          | 32    | EINT interrupt mask set register          |
| A2100330            | <u>EINT MASK CLR</u>          | 32    | EINT interrupt mask clear register        |
| A2100340            | <u>EINT WAKEUP MASK</u>       | 32    | EINT wakeup event mask register           |
| A2100348            | <u>EINT WAKEUP MASK SET</u>   | 32    | EINT wakeup event mask set register       |
| A2100350            | <u>EINT WAKEUP MASK CLR</u>   | 32    | EINT wakeup event mask clear register     |
| A2100360            | <u>EINT SENS</u>              | 32    | EINT sensitivity register                 |
| A2100368            | <u>EINT SENS SET</u>          | 32    | EINT sensitivity set register             |
| A2100370            | <u>EINT SENS CLR</u>          | 32    | EINT sensitivity clear register           |
| A2100380            | <u>EINT DUALEDGE SENS</u>     | 32    | EINT dual edge sensitivity register       |
| A2100388            | <u>EINT DUALEDGE SENS SET</u> | 32    | EINT dual edge sensitivity set register   |
| A2100390            | <u>EINT DUALEDGE SENS CLR</u> | 32    | EINT dual edge sensitivity clear register |
| A21003A0            | <u>EINT POL</u>               | 32    | EINT polarity register                    |
| A21003A8            | <u>EINT POL SET</u>           | 32    | EINT polarity set register                |
| A21003B0            | <u>EINT POL CLR</u>           | 32    | EINT polarity clear register              |
| A21003C0            | <u>EINT SOFT</u>              | 32    | EINT software interrupt register          |
| A21003C8            | <u>EINT SOFT SET</u>          | 32    | EINT software interrupt set register      |
| A21003D0            | <u>EINT SOFT CLR</u>          | 32    | EINT software interrupt clear register    |
| A2100400 ~ A210047C | <u>EINTi CON[n] (n=0~31)</u>  | 32    | EINTi configuration register              |

#### 3.7.1. Register definitions

**A2100300 EINT STA EINT interrupt status register 00000000**

| Bit                    | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Mne</b>             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit                    | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Mne</b>             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>EINT STA[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| RO                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>EINT STA[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| RO                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit(s) | Mnemonic | Name                      | Description                                                                                                                                       |
|--------|----------|---------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | EINT_STA | External interrupt status | This register tracks interrupt request status generated by certain EINT sources. If the EINT sources are set to edge sensitivity, EINT_IRQ is de- |

asserted while the corresponding EINT\_INTACK is set to 1.  
EINT\_STA[i] for EINTi.

- 0: No external interrupt request is generated.
- 1: External interrupt request is pending.

#### A2100308 EINT\_INTACK EINT interrupt acknowledge register 00000000

| Bit   | 31                 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|--------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Mne   | EINT_INTACK[31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | WO                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15                 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Mne   | EINT_INTACK[15:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | WO                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Mnemonic    | Name                             | Description                                                                                                                                                                                                                  |
|--------|-------------|----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | EINT_INTACK | <b>Interrupt acknowledgement</b> | Writing "1" to the specific bit position will acknowledge the interrupt request correspondingly to the external interrupt line source.<br>EINT_INTACK[i] for EINTi.<br>0: No effect<br>1: Interrupt request is acknowledged. |

#### A2100310 EINT\_EEVT EINT wakeup event\_b status register 00010000

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit(s) | Mnemonic | Name                        | Description                                                                                                                                                                                          |
|--------|----------|-----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | EEB      | <b>EINT wake up event_b</b> | This register is a debugging port to monitor internal signals. It is an asynchronous signal.<br>0: EINT wakes up the system from sleep mode.<br>1: EINT does not wake up the system from sleep mode. |

#### A2100320 EINT\_MASK EINT interrupt mask register FFFFFFFF

| Bit   | 31                              | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|---------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | EINT_MASK[31:16]                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15                              | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | EINT_MASK[15:0]                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit(s) | Mnemonic  | Name                  | Description                                                           |
|--------|-----------|-----------------------|-----------------------------------------------------------------------|
| 31:0   | EINT_MASK | <b>Interrupt mask</b> | This register controls whether the EINT source is allowed to generate |

| Bit(s) | Mnemonic | Name | Description                                                                                                                                                                                                              |
|--------|----------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |          |      | an interrupt request. Setting a specific bit position to "1" will prevent activation of the external interrupt line.<br>EINT_MASK[i] for EINTi.<br>0: Interrupt request is enabled.<br>1: Interrupt request is disabled. |

|          |                    |                                  |          |
|----------|--------------------|----------------------------------|----------|
| A2100328 | <b>EINT MASK S</b> | EINT interrupt mask set register | 00000000 |
|----------|--------------------|----------------------------------|----------|

| Bit   | 31               | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | EINT_MASK[31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | WO               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15               | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | EINT_MASK[15:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | WO               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Mnemonic  | Name                                                             | Description                                                                                                                                                                                                                |
|--------|-----------|------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | EINT_MASK | <b>Enables mask for the associated external interrupt source</b> | This register is used to set up individual mask bits. Only the bits set to 1 are effective. EINT_MASK bits are also set to 1. Otherwise, EINT_MASK[i] for EINTi.<br>0: No effect<br>1: Enables the corresponding MASK bit. |

|          |                    |                                    |          |
|----------|--------------------|------------------------------------|----------|
| A2100330 | <b>EINT MASK C</b> | EINT interrupt mask clear register | 00000000 |
|----------|--------------------|------------------------------------|----------|

| Bit   | 31               | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | EINT_MASK[31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | WO               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15               | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | EINT_MASK[15:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | WO               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Mnemonic  | Name                                                              | Description                                                                                                                                                                                                                          |
|--------|-----------|-------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | EINT_MASK | <b>Disables mask for the associated external interrupt source</b> | This register is used to clear individual mask bits. Only the bits set to 1 are effective. EINT_MASK bits are also cleared (set to 0). Otherwise, EINT_MASK[i] for EINTi.<br>0: No effect<br>1: Disables the corresponding MASK bit. |

|          |                   |                                 |            |
|----------|-------------------|---------------------------------|------------|
| A2100340 | <b>EINT WAKEU</b> | EINT wakeup event mask register | FFFFFFFFFF |
|----------|-------------------|---------------------------------|------------|

| Bit   | 31                      | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|-------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | EINT_WAKEUP_MASK[31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 1                       | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  |
| Bit   | 15                      | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | EINT_WAKEUP_MASK[15:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

|              |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|--------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| <b>Reset</b> | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
|--------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|

| <b>Bit(s)</b> | <b>Mnemonic</b>      | <b>Name</b>              | <b>Description</b>                                                                                                                                                                                                                                                                                            |
|---------------|----------------------|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0          | EINT_WAKEUP_M<br>ASK | <b>Wakeup event mask</b> | This register controls whether the EINT source is allowed to generate a wakeup event request. Setting a specific bit position to "1" will prevent activation of the external interrupt line.<br>EINT_WAKEUP_MASK[i] for EINTi.<br>0: Wakeup event request is enabled.<br>1: Wakeup event request is disabled. |

| <b>A2100348 EINT_WAKEUP MASK SET</b> |                                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|--------------------------------------|--------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Bit</b>                           | 31                             | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b>                          | <b>EINT_WAKEUP_MASK[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                          | WO                             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                         | 0                              | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>                           | 15                             | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>                          | <b>EINT_WAKEUP_MASK[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                          | WO                             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                         | 0                              | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| <b>Bit(s)</b> | <b>Mnemonic</b>      | <b>Name</b>                                                      | <b>Description</b>                                                                                                                                                                                                                       |
|---------------|----------------------|------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0          | EINT_WAKEUP_M<br>ASK | <b>Enables mask for the associated external interrupt source</b> | This register is used to set up individual mask bits. Only the bits set to 1 are effective. EINT_WAKEUP_MASK bits are also set to 1. Otherwise, EINT_WAKEUP_MASK[i] for EINTi.<br>0: No effect<br>1: Enables the corresponding MASK bit. |

| <b>A2100350 EINT_WAKEUP MASK CLR</b> |                                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|--------------------------------------|--------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Bit</b>                           | 31                             | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b>                          | <b>EINT_WAKEUP_MASK[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                          | WO                             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                         | 0                              | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>                           | 15                             | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>                          | <b>EINT_WAKEUP_MASK[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                          | WO                             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                         | 0                              | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| <b>Bit(s)</b> | <b>Mnemonic</b>      | <b>Name</b>                                                       | <b>Description</b>                                                                                                                                                                                                                                 |
|---------------|----------------------|-------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0          | EINT_WAKEUP_M<br>ASK | <b>Disables mask for the associated external interrupt source</b> | This register is used to clear individual mask bits. Only the bits set to 1 are effective. EINT_WAKEUP_MASK bits are also cleared (set to 0). Otherwise, EINT_WAKEUP_MASK[i] for EINTi.<br>0: No effect<br>1: Disables the corresponding MASK bit. |

| <b>A2100360 EINT_SENS</b> |                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|---------------------------|-------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Bit</b>                | 31                      | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b>               | <b>EINT_SENS[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

|              |                        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |   |
|--------------|------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|---|
| <b>Type</b>  | RO                     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |   |
| <b>Reset</b> | 0                      | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| <b>Bit</b>   | 15                     | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |   |
| <b>Name</b>  | <b>EINT_SENS[15:0]</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>  | RO                     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |   |
| <b>Reset</b> | 0                      | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| Bit(s) | Mnemonic | Name      | Description                                                                                                                                                                                                                                                                             |
|--------|----------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   |          | EINT_SENS | <b>Sensitivity type of the associated external interrupt source</b><br>Sensitivity type of external interrupt source.<br>EINT_SENS[i] for EINTi.<br>0: Edge sensitivity (active high or low depends on POL setting)<br>1: Level sensitivity (active high or low depends on POL setting) |

| A2100368 <b>EINT_SENS_S</b> EINT sensitivity set register <b>00000000</b> |                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|---------------------------------------------------------------------------|-------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit                                                                       | 31                      | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b>                                                               | <b>EINT_SENS[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                                                               | WO                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                                                              | 0                       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>                                                                | 15                      | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>                                                               | <b>EINT_SENS[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                                                               | WO                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                                                              | 0                       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Mnemonic | Name      | Description                                                                                                                                                                                                                                                                                                                                                 |
|--------|----------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   |          | EINT_SENS | <b>Enables sensitive for the associated external interrupt source.</b><br>This register is used to set up individual sensitive bits. Only the bits set to 1 are effective. EINT_SENS bits are also set to 1. Otherwise, EINT_SENS bits will retain the original value.<br>EINT_SENS[i] for EINTi.<br>0: No effect<br>1: Enables the corresponding SENS bit. |

| A2100370 <b>EINT_SENS_C</b> EINT sensitivity clear register <b>00000000</b> |                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-----------------------------------------------------------------------------|-------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit                                                                         | 31                      | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b>                                                                 | <b>EINT_SENS[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                                                                 | WO                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                                                                | 0                       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>                                                                  | 15                      | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>                                                                 | <b>EINT_SENS[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                                                                 | WO                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                                                                | 0                       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Mnemonic | Name      | Description                                                                                                                                                                                                                                                                                                                                                            |
|--------|----------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   |          | EINT_SENS | <b>Disables sensitive for the associated external interrupt source.</b><br>This register is used to clear individual sensitive bits. Only the bits set to 1 are effective. EINT_SENS bits are also cleared (set to 0). Otherwise, EINT_SENS bits will retain the original value.<br>EINT_SENS[i] for EINTi.<br>0: No effect<br>1: Disables the corresponding SENS bit. |

**A2100380 EINT\_DUALED GE\_SENS** EINT dual edge sensitivity register **oooooooooooo**

| Bit   | 31                        | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|---------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | EINT_DUALEDGE_SENS[31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15                        | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | EINT_DUALEDGE_SENS[15:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Mnemonic           | Name                                                                   | Description                                                                                                                                                                                |
|--------|--------------------|------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | EINT_DUALEDGE_SENS | Dual edge sensitivity type of the associated external interrupt source | <p>Dual edge sensitivity type of external interrupt source. (EINT_SENS should be 0)</p> <p>EINT_DUALEDGE_SENS[i] for EINTi.</p> <p>0: Disable</p> <p>1: Enable (no dependency on POL).</p> |

**A2100388 EINT\_DUALED GE\_SENS\_SET** EINT dual edge sensitivity set register **oooooooooooo**

| Bit   | 31                        | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|---------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | EINT_DUALEDGE_SENS[31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | WO                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15                        | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | EINT_DUALEDGE_SENS[15:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | WO                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Mnemonic           | Name                                                                        | Description                                                                                                                                                                                                                                                                                                                                                                  |
|--------|--------------------|-----------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | EINT_DUALEDGE_SENS | Enables dual edge sensitivity for the associated external interrupt source. | <p>This register is used to set up individual dual edge sensitive bits. (EINT_SENS should be 0)</p> <p>Only the bits set to 1 are effective. EINT_DUALEDGE_SENS bits are also set to 1. Otherwise, EINT_DUALEDGE_SENS bits will retain the original value.</p> <p>EINT_DUALEDGE_SENS[i] for EINTi.</p> <p>0: No effect</p> <p>1: Enables the corresponding DUALEDGE bit.</p> |

**A2100390 EINT\_DUALED GE\_SENS\_CLR** EINT dual edge sensitivity clear register **oooooooooooo**

| Bit   | 31                        | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|---------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | EINT_DUALEDGE_SENS[31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | WO                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15                        | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | EINT_DUALEDGE_SENS[15:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | WO                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Mnemonic | Name               | Description                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------|----------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   |          | EINT_DUALEDGE_SENS | <p><b>Disables dual edge sensitive for the associated external interrupt source.</b></p> <p>This register is used to clear individual sensitive bits. Only the bits set to 1 are effective. EINT_DUALEDGE_SENS bits are also cleared (set to 0). Otherwise, EINT_DUALEDGE_SENS bits will retain the original value.</p> <p>EINT_DUALEDGE_SENS[i] for EINTi.</p> <p>0: No effect<br/>1: Disables the corresponding DUALEDGE bit.</p> |

**A21003Ao EINT\_POL EINT polarity register 00000000**

| Bit                    | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>EINT_POL[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| RO                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset                  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>EINT_POL[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| RO                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset                  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Mnemonic | Name     | Description                                                                                                                                                                                  |
|--------|----------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   |          | EINT_POL | <p><b>Configures polarity of the associated external interrupt source.</b></p> <p>Activation type of the EINT source.<br/>EINT_POL[i] for EINTi.</p> <p>0: Active low<br/>1: Active high</p> |

**A21003A8 EINT\_POL\_SE T EINT polarity set register 00000000**

| Bit                    | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>EINT_POL[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| WO                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset                  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>EINT_POL[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| WO                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset                  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Mnemonic | Name     | Description                                                                                                                                                                                                                                                                                                                                                                         |
|--------|----------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   |          | EINT_POL | <p><b>Enables polarity configuration for the associated external interrupt source</b></p> <p>This register is used to set up individual polarity bits. Only the bits set to 1 are effective. EINT_POL bits are also set to 1. Otherwise, EINT_POL bits will retain the original value.<br/>EINT_POL[i] for EINTi.</p> <p>0: No effect<br/>1: Enables the corresponding POL bit.</p> |

**A21003Bo EINT\_POL\_CL R EINT polarity clear register 00000000**

| Bit                    | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>EINT_POL[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| WO                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset                  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

|              |                       |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------------|-----------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Bit</b>   | 15                    | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| <b>Name</b>  | <b>EINT_POL[15:0]</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>  | WO                    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Reset</b> | 0                     | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                         |
|---------------|-----------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0          |                 | EINT_POL    | <p><b>Polarity configuration set</b></p> <p>This register is used to clear individual polarity bits. Only the bits set to 1 are effective. EINT_POL bits are also cleared (set to 0). Otherwise, EINT_POL[i] for EINTi.</p> <p>0: No effect<br/>1: Disables the corresponding POL bit.</p> |

| <b>A21003Co EINT_SOFT EINT software interrupt register</b> |                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 00000000 |
|------------------------------------------------------------|-------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|
| <b>Bit</b>                                                 | 31                      | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16       |
| <b>Name</b>                                                | <b>EINT_SOFT[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |
| <b>Type</b>                                                | RO                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |
| <b>Reset</b>                                               | 0                       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0        |
| <b>Bit</b>                                                 | 15                      | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0        |
| <b>Name</b>                                                | <b>EINT_SOFT[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |
| <b>Type</b>                                                | RO                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |
| <b>Reset</b>                                               | 0                       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0        |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b> | <b>Description</b>                                                                                                                                        |
|---------------|-----------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0          |                 | EINT_SOFT   | <p><b>Software interrupt</b></p> <p>This register is used for debugging purposes. EINT_SOFT[i] for EINTi.</p> <p>0: No effect<br/>1: Triggers an EINT</p> |

| <b>A21003C8 EINT_SOFT_S ET EINT software interrupt set register</b> |                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 00000000 |
|---------------------------------------------------------------------|-------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|
| <b>Bit</b>                                                          | 31                      | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16       |
| <b>Name</b>                                                         | <b>EINT_SOFT[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |
| <b>Type</b>                                                         | WO                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |
| <b>Reset</b>                                                        | 0                       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0        |
| <b>Bit</b>                                                          | 15                      | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0        |
| <b>Name</b>                                                         | <b>EINT_SOFT[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |
| <b>Type</b>                                                         | WO                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |
| <b>Reset</b>                                                        | 0                       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0        |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                     |
|---------------|-----------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0          |                 | EINT_SOFT   | <p><b>Enables software for the associated external interrupt source</b></p> <p>This register is used to set up individual software bits. Only the bits set to 1 are effective. EINT_SOFT bits are also set to 1. Otherwise, EINT_SOFT[i] for EINTi.</p> <p>0: No effect<br/>1: Enables the corresponding SOFT bit.</p> |

| <b>A21003Do EINT_SOFT_C LR EINT software interrupt clear register</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 00000000 |
|-----------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|
| <b>Bit</b>                                                            | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16       |

| Name  | EINT_SOFT[31:16] |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------|------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Type  | WO               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0                | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Bit   | 15               | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name  | EINT_SOFT[15:0]  |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | WO               |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0                | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| Bit(s) | Mnemonic  | Name                                                                  | Description                                                                                                                                                                                                                                                                                                |
|--------|-----------|-----------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | EINT_SOFT | <b>Disables software for the associated external interrupt source</b> | <p>This register is used to clear individual software bits. Only the bits set to 1 are effective. EINT_SOFT bits are also cleared (set to 0). Otherwise, EINT_SOFT bits will retain the original value.</p> <p>EINT_SOFT[i] for EINTi.</p> <p>0: No effect<br/>1: Disables the corresponding SOFT bit.</p> |

**A2100400~ A210047C EINTi CON[n] (n=0~31) EINTi config register (step = 0x4) 00000000**

| Bit   | 31      | 30 | 29 | 28 | 27 | 26 | 25       | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16     |
|-------|---------|----|----|----|----|----|----------|----|----|----|----|----|----|----|----|--------|
| Name  |         |    |    |    |    |    | RSTD_B_C |    |    |    |    |    |    |    |    | DBC_EN |
| Type  |         |    |    |    |    |    | WO       |    |    |    |    |    |    |    |    | RW     |
| Reset |         |    |    |    |    |    | 0        |    |    |    |    |    |    |    |    | 0      |
| Bit   | 15      | 14 | 13 | 12 | 11 | 10 | 9        | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0      |
| Name  | DBC_CON |    |    |    |    |    |          |    |    |    |    |    |    |    |    |        |
| Type  | RW      |    |    |    |    |    |          |    |    |    |    |    |    |    |    |        |
| Reset | 0       | 0  | 0  | 0  | 0  | 0  | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0      |

| Bit(s) | Mnemonic | Name                                 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------|----------|--------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24     | RSTDBC   | <b>EINTi debounce count reset</b>    | <p>Write 1 to reset the de-bounce counter so that EINT can be updated immediately without de-bounce latency. This option needs 100usec latency to take effect.</p> <p>0: no effect<br/>1: reset</p>                                                                                                                                                                                                                                                                                                                                |
| 16     | DBC_EN   | <b>EINTi debounce circuit enable</b> | <p>0: disable<br/>1: enable</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 14:0   | DBC_CON  | <b>EINTi debounce count setting</b>  | <p>DBC_CNT = DBC_CON[10:0]<br/>EINTi debounce duration config<br/>(clock period is determined in PRESCALER)<br/><i>Note: When DBD_CON[10:0] = 0 and DBC_EN = 1, there are still two 32K clock cycles (62.5 us) debounce. If you want to disable debounce function, DBC_EN should be set to 0 (Zero).</i></p> <p>PRESCALER = DBC_CON[14:12]<br/>EINTi debounce clock cycle period prescaler.<br/>000: 32,768Hz, max. 0.0625sec<br/>001: 16,384Hz<br/>010: 8,192Hz<br/>011: 4,096Hz<br/>100: 2,048Hz, max. 1sec<br/>101: 1,024Hz</p> |

| Bit(s) | Mnemonic | Name | Description            |
|--------|----------|------|------------------------|
|        |          |      | 110: 512Hz             |
|        |          |      | 111: 256Hz, max. 8secs |

## 4. Direct Memory Access

### 4.1. Overview

A DMA controller is placed on AHB bus to support fast data transfers and off-load the processor. With this controller, specific devices on AHB or APB buses can benefit greatly from quick completion of data movement from or to memory modules. Such generic DMA controller can also be used to connect two devices other than memory modules as long as they can be addressed in memory space. Figure 4.1-1 illustrates the system connections.



*Figure 4.1-1. Variety data paths of DMA transfers*

### 4.2. Features

There is a round-robin arbitration mechanism to support up to 16 channels working simultaneously. Each channel has a similar set of registers to be configured to different schemes as desired. Both interrupt and polling based schemes are supported to handle the completion events.

The block diagram of DMA operation is shown in Figure 4.2-1.



**Figure 4.2-1. DMA block diagram**

## 4.3. Functions

There are three types of DMA channels in the DMA controller: full-size DMA, half-size DMA and virtual FIFO DMA. Channel 1 is a full-size DMA channel, channels 2 to 6 are half-size channels and channels 7 to 16 are virtual FIFO DMA channels. The difference between the first two types of DMA channels is that source and destination addresses are programmable as full-size DMA channels, but the address of either source or destination only can be programmed as a half-size DMA channel, while the address of the other side is fixed.

### 4.3.1. Ring buffer and double buffer memory data transfer

DMA channels 1 to 7 support ring-buffer and double-buffer memory data transfer. This can be achieved by programming DMA\_WPPT and DMA\_WPTO, as well as setting up WPEN in the DMA\_CON register to enable, as shown in Figure 4.3-1. The next address jumps to WPTO address after WPPT data transfer is complete, once the transfer counter reaches WPPT.

Note that only one side can be configured as ring-buffer or double-buffer memory, and this is controlled by WPSD in the DMA\_CON register.



Figure 4.3-1. Ring buffer and double buffer memory data movement

#### 4.3.2. Unaligned word access

The address of word access on AHB bus must be aligned to word boundary (the address must be multiple of 4), or the two LSB are truncated to 00b. If the LSB is truncated incorrect data may be fetched. If the data is moved from unaligned to aligned address, the word is usually split into four bytes then moved byte by byte. Thus, the four read and four write transfers will appear on the bus.

To improve bus efficiency, the unaligned-word access is provided in DMA 2 to 7. If “byte-to-word (B2W)” function is enabled in PDMAx\_CON, the DMAs will move data from the unaligned address to aligned address by executing four continuous byte-read accesses and one word-write access, reducing the number of transfers on the bus by three, as shown in Figure 4.3-2.



Figure 4.3-2. Unaligned word accesses

#### 4.3.3. Virtual FIFO DMA

Virtual FIFO DMA is used to ease UART control. The difference between the virtual FIFO DMA and the ordinary DMA is that the virtual FIFO DMA contains additional FIFO controllers. The read and write pointers are kept in the virtual FIFO DMA. To read from FIFO, the read pointer points to the address of the next data. To write into the FIFO, the write pointer moves to the next address. If the FIFO is empty, a FIFO read will not be allowed. Similarly, the data will not be written to the FIFO if the FIFO is full. Due to UART flow control requirements, an alert length

(VDMAx\_ALTLEN) is programmed. If the FIFO space is smaller than this value, an alert signal is issued to enable the UART flow control. The type of flow control performed depends on the UART configuration settings.

Each virtual FIFO DMA can be programmed as receive (RX) or transmit (TX) FIFO. This depends on the DIR setting in the DMA\_CON register. If DIR is “0” (READ), the virtual FIFO DMA is specified as a TX FIFO. On the other hand, if DIR is “1” (WRITE), the virtual FIFO DMA will be specified as an RX FIFO.

The virtual FIFO DMA provides an interrupt to MCU to notify data availability in the FIFO and the amount of data is above or under the value defined in the DMA\_COUNT register. Based on this, the MCU does not need to poll the DMA to know when the data must be removed from or put into the FIFO.



*Figure 4.3-3. Virtual FIFO DMA*

#### 4.4. Application and programming sequence

DMA channels 7 to 16 are virtual FIFO DMA with corresponding peripherals. The access ports for the MCU of each VDMA are listed in Table 4.4-1. MCU treats the virtual FIFO access port as a real FIFO, but the physical location or size is configured by registers of each channel.

*Table 4.4-1. Virtual FIFO access ports*

| DMA number | Address of virtual FIFO access port | Reference UART |
|------------|-------------------------------------|----------------|
| DMA7       | A100_0000h                          | AUD_TX         |
| DMA8       | A100_0100h                          | AUD_RX         |
| DMA9       | A100_0200h                          | ASYS TX        |
| DMA10      | A100_0300h                          | ASYS RX        |
| DMA11      | A100_0400h                          | UART2 TX       |
| DMA12      | A100_0500h                          | UART2 RX       |
| DMA13      | A100_0600h                          | UART1 TX       |

| DMA number | Address of virtual FIFO access port | Reference UART |
|------------|-------------------------------------|----------------|
| DMA14      | A100_0700h                          | UART1 RX       |
| DMA15      | A100_0800h                          | UART0 TX       |
| DMA16      | A100_0900h                          | UART0 RX       |

Due to different types of DMA, the limitations for each peripheral are listed below.

*Table 4-2. Function list of DMA channels*

| DMA number | Type         | Ring buffer | Double buffer | Burst mode | Unaligned word access | Peripheral |
|------------|--------------|-------------|---------------|------------|-----------------------|------------|
| DMA1       | Full size    | •           | •             | •          |                       |            |
| DMA2       | Half size    | •           | •             | •          | •                     | I2C0 TX    |
| DMA3       | Half size    | •           | •             | •          | •                     | I2C0 RX    |
| DMA4       | Half size    | •           | •             | •          | •                     | I2C1 TX    |
| DMA5       | Half size    | •           | •             | •          | •                     | I2C1 RX    |
| DMA6       | Half size    | •           | •             | •          | •                     | HIF_TX, RX |
| DMA7       | Virtual FIFO | •           |               |            |                       | AUD_TX     |
| DMA8       | Virtual FIFO | •           |               |            |                       | AUD_RX     |
| DMA9       | Virtual FIFO | •           |               |            |                       | ASYS TX    |
| DMA10      | Virtual FIFO | •           |               |            |                       | ASYS RX    |
| DMA11      | Virtual FIFO | •           |               |            |                       | UART2 TX   |
| DMA12      | Virtual FIFO | •           |               |            |                       | UART2 RX   |
| DMA13      | Virtual FIFO | •           |               |            |                       | UART1 TX   |
| DMA14      | Virtual FIFO | •           |               |            |                       | UART1 RX   |
| DMA15      | Virtual FIFO | •           |               |            |                       | UART0 TX   |
| DMA16      | Virtual FIFO | •           |               |            |                       | UART0 RX   |

## 4.5. Register mapping

There are 16 DMA channels in this SOC. The usage of the registers below is the same except that the base address should be changed to respective ones.

**Module name: DMA Base address: (+a002000oh)**

| Address | Name | Width | Register Functionality |
|---------|------|-------|------------------------|
|         |      |       |                        |

|          |                          |    |                                                    |
|----------|--------------------------|----|----------------------------------------------------|
| A0020000 | <b>DMA_GLBSTA</b>        | 32 | DMA global status                                  |
| A0020008 | <b>DMA_GLB_CPUo_CF_G</b> | 32 | DMA top hierarchy interrupt configuration          |
| A002000C | <b>DMA_GLB_CPUo_SE_T</b> | 32 | DMA top hierarchy interrupt setting                |
| A0020010 | <b>DMA_GLB_CPUo_CL_R</b> | 32 | DMA top hierarchy interrupt clear                  |
| A0020028 | <b>DMA_GLBLIMITER</b>    | 32 | DMA global bandwidth limiter register              |
| A0020020 | <b>DMA_GLB_SWRST</b>     | 32 | DMA global software reset                          |
| A0020040 | <b>DMA_GLB_BUSY</b>      | 32 | DMA global busy status                             |
| A0020044 | <b>DMA_GLB_INTR</b>      | 32 | DMA global interrupt status                        |
| A0020100 | <b>GDMA1_SRC</b>         | 32 | DMA channel 1 source address                       |
| A0020104 | <b>GDMA1_DST</b>         | 32 | DMA channel 1 destination address                  |
| A0020108 | <b>GDMA1_WPPT</b>        | 32 | DMA channel 1 wrap point address                   |
| A002010C | <b>GDMA1_WPTO</b>        | 32 | DMA channel 1 wrap to address                      |
| A0020110 | <b>GDMA1_COUNT</b>       | 32 | DMA channel 1 transfer count                       |
| A0020114 | <b>GDMA1_CON</b>         | 32 | DMA channel 1 control                              |
| A0020118 | <b>GDMA1_START</b>       | 32 | DMA channel 1 start                                |
| A002011C | <b>GDMA1_INTSTA</b>      | 32 | DMA channel 1 interrupt status                     |
| A0020120 | <b>GDMA1_ACKINT</b>      | 32 | DMA channel 1 interrupt acknowledge                |
| A0020124 | <b>GDMA1_RLCT</b>        | 32 | DMA channel 1 remaining length of current transfer |
| A0020128 | <b>GDMA1_LIMITER</b>     | 32 | DMA channel 1 bandwidth limiter                    |
| A0020208 | <b>PDMA2_WPPT</b>        | 32 | DMA channel 2 wrap point address                   |
| A002020C | <b>PDMA2_WPTO</b>        | 32 | DMA channel 2 wrap to address                      |
| A0020210 | <b>PDMA2_COUNT</b>       | 32 | DMA channel 2 transfer count                       |
| A0020214 | <b>PDMA2_CON</b>         | 32 | DMA channel 2 control                              |
| A0020218 | <b>PDMA2_START</b>       | 32 | DMA channel 2 start                                |
| A002021C | <b>PDMA2_INTSTA</b>      | 32 | DMA channel 2 interrupt status                     |
| A0020220 | <b>PDMA2_ACKINT</b>      | 32 | DMA channel 2 interrupt acknowledge                |
| A0020224 | <b>PDMA2_RLCT</b>        | 32 | DMA channel 2 remaining length of current transfer |
| A0020228 | <b>PDMA2_LIMITER</b>     | 32 | DMA channel 2 bandwidth limiter                    |
| A002022C | <b>PDMA2_PGMADDR</b>     | 32 | DMA channel 2 programmable address                 |
| A0020308 | <b>PDMA3_WPPT</b>        | 32 | DMA channel 3 wrap point address                   |
| A002030C | <b>PDMA3_WPTO</b>        | 32 | DMA channel 3 wrap to address                      |
| A0020310 | <b>PDMA3_COUNT</b>       | 32 | DMA channel 3 transfer count                       |
| A0020314 | <b>PDMA3_CON</b>         | 32 | DMA channel 3 control                              |
| A0020318 | <b>PDMA3_START</b>       | 32 | DMA channel 3 start                                |
| A002031C | <b>PDMA3_INTSTA</b>      | 32 | DMA channel 3 interrupt status                     |
| A0020320 | <b>PDMA3_ACKINT</b>      | 32 | DMA channel 3 interrupt acknowledge                |
| A0020324 | <b>PDMA3_RLCT</b>        | 32 | DMA channel 3 remaining length of                  |

|          |                      |    |                                                    |
|----------|----------------------|----|----------------------------------------------------|
|          |                      |    | <b>current transfer</b>                            |
| A0020328 | <b>PDMA3 LIMITER</b> | 32 | DMA channel 3 bandwidth limiter                    |
| A002032C | <b>PDMA3 PGMADDR</b> | 32 | DMA channel 3 programmable address                 |
| A0020408 | <b>PDMA4 WPPT</b>    | 32 | DMA channel 4 wrap point address                   |
| A002040C | <b>PDMA4 WPTO</b>    | 32 | DMA channel 4 wrap to address                      |
| A0020410 | <b>PDMA4 COUNT</b>   | 32 | DMA channel 4 transfer count                       |
| A0020414 | <b>PDMA4 CON</b>     | 32 | DMA channel 4 control                              |
| A0020418 | <b>PDMA4 START</b>   | 32 | DMA channel 4 start                                |
| A002041C | <b>PDMA4 INTSTA</b>  | 32 | DMA channel 4 interrupt status                     |
| A0020420 | <b>PDMA4 ACKINT</b>  | 32 | DMA channel 4 interrupt acknowledge                |
| A0020424 | <b>PDMA4 RLCT</b>    | 32 | DMA channel 4 remaining length of current transfer |
| A0020428 | <b>PDMA4 LIMITER</b> | 32 | DMA channel 4 bandwidth limiter                    |
| A002042C | <b>PDMA4 PGMADDR</b> | 32 | DMA channel 4 programmable address                 |
| A0020508 | <b>PDMA5 WPPT</b>    | 32 | DMA channel 5 wrap point address                   |
| A002050C | <b>PDMA5 WPTO</b>    | 32 | DMA channel 5 wrap to address                      |
| A0020510 | <b>PDMA5 COUNT</b>   | 32 | DMA channel 5 transfer count                       |
| A0020514 | <b>PDMA5 CON</b>     | 32 | DMA channel 5 control                              |
| A0020518 | <b>PDMA5 START</b>   | 32 | DMA channel 5 start                                |
| A002051C | <b>PDMA5 INTSTA</b>  | 32 | DMA channel 5 interrupt status                     |
| A0020520 | <b>PDMA5 ACKINT</b>  | 32 | DMA channel 5 interrupt acknowledge                |
| A0020524 | <b>PDMA5 RLCT</b>    | 32 | DMA channel 5 remaining length of current transfer |
| A0020528 | <b>PDMA5 LIMITER</b> | 32 | DMA channel 5 bandwidth limiter                    |
| A002052C | <b>PDMA5 PGMADDR</b> | 32 | DMA channel 5 programmable address                 |
| A0020608 | <b>PDMA6 WPPT</b>    | 32 | DMA channel 6 wrap point address                   |
| A002060C | <b>PDMA6 WPTO</b>    | 32 | DMA channel 6 wrap to address                      |
| A0020610 | <b>PDMA6 COUNT</b>   | 32 | DMA channel 6 transfer count                       |
| A0020614 | <b>PDMA6 CON</b>     | 32 | DMA channel 6 control                              |
| A0020618 | <b>PDMA6 START</b>   | 32 | DMA channel 6 start                                |
| A002061C | <b>PDMA6 INTSTA</b>  | 32 | DMA channel 6 interrupt status                     |
| A0020620 | <b>PDMA6 ACKINT</b>  | 32 | DMA channel 6 interrupt acknowledge                |
| A0020624 | <b>PDMA6 RLCT</b>    | 32 | DMA channel 6 remaining length of current transfer |
| A0020628 | <b>PDMA6 LIMITER</b> | 32 | DMA channel 6 bandwidth limiter                    |
| A002062C | <b>PDMA6 PGMADDR</b> | 32 | DMA channel 6 programmable address                 |
| A0020710 | <b>VDMA7 COUNT</b>   | 32 | DMA channel 7 transfer count                       |
| A0020714 | <b>VDMA7 CON</b>     | 32 | DMA channel 7 control                              |
| A0020718 | <b>VDMA7 START</b>   | 32 | DMA channel 7 start register                       |
| A002071C | <b>VDMA7 INTSTA</b>  | 32 | DMA channel 7 interrupt status                     |
| A0020720 | <b>VDMA7 ACKINT</b>  | 32 | DMA channel 7 interrupt acknowledge                |

|          |                       |    |                                     |
|----------|-----------------------|----|-------------------------------------|
| A0020728 | <b>VDMA7 LIMITER</b>  | 32 | DMA channel 7 bandwidth limiter     |
| A002072C | <b>VDMA7 PGMAADDR</b> | 32 | DMA channel 7 programmable address  |
| A0020730 | <b>VDMA7 WRPTR</b>    | 32 | DMA channel 7 write pointer         |
| A0020734 | <b>VDMA7 RDPTR</b>    | 32 | DMA channel 7 read pointer          |
| A0020738 | <b>VDMA7 FFCNT</b>    | 32 | DMA channel 7 FIFO count            |
| A002073C | <b>VDMA7 FFSTA</b>    | 32 | DMA channel 7 FIFO status           |
| A0020740 | <b>VDMA7 ALTLEN</b>   | 32 | DMA channel 7 alert length          |
| A0020744 | <b>VDMA7 FFSIZE</b>   | 32 | DMA channel 7 FIFO size             |
| A0020810 | <b>VDMA8 COUNT</b>    | 32 | DMA channel 8 transfer count        |
| A0020814 | <b>VDMA8 CON</b>      | 32 | DMA channel 8 control               |
| A0020818 | <b>VDMA8 START</b>    | 32 | DMA channel 8 start register        |
| A002081C | <b>VDMA8 INTSTA</b>   | 32 | DMA channel 8 interrupt status      |
| A0020820 | <b>VDMA8 ACKINT</b>   | 32 | DMA channel 8 interrupt acknowledge |
| A0020828 | <b>VDMA8 LIMITER</b>  | 32 | DMA channel 8 bandwidth limiter     |
| A002082C | <b>VDMA8 PGMAADDR</b> | 32 | DMA channel 8 programmable address  |
| A0020830 | <b>VDMA8 WRPTR</b>    | 32 | DMA channel 8 write pointer         |
| A0020834 | <b>VDMA8 RD PTR</b>   | 32 | DMA channel 8 read pointer          |
| A0020838 | <b>VDMA8 FFCNT</b>    | 32 | DMA channel 8 FIFO count            |
| A002083C | <b>VDMA8 FFSTA</b>    | 32 | DMA channel 8 FIFO status           |
| A0020840 | <b>VDMA8 ALTLEN</b>   | 32 | DMA channel 8 alert length          |
| A0020844 | <b>VDMA8 FFSIZE</b>   | 32 | DMA channel 8 FIFO size             |
| A0020910 | <b>VDMA9 COUNT</b>    | 32 | DMA channel 9 transfer count        |
| A0020914 | <b>VDMA9 CON</b>      | 32 | DMA channel 9 control               |
| A0020918 | <b>VDMA9 START</b>    | 32 | DMA channel 9 start register        |
| A002091C | <b>VDMA9 INTSTA</b>   | 32 | DMA channel 9 interrupt status      |
| A0020920 | <b>VDMA9 ACKINT</b>   | 32 | DMA channel 9 interrupt acknowledge |
| A0020928 | <b>VDMA9 LIMITER</b>  | 32 | DMA channel 9 bandwidth limiter     |
| A002092C | <b>VDMA9 PGMAADDR</b> | 32 | DMA channel 9 programmable address  |
| A0020930 | <b>VDMA9 WRPTR</b>    | 32 | DMA channel 9 write pointer         |
| A0020934 | <b>VDMA9 RD PTR</b>   | 32 | DMA channel 9 read pointer          |
| A0020938 | <b>VDMA9 FFCNT</b>    | 32 | DMA channel 9 FIFO count            |
| A002093C | <b>VDMA9 FFSTA</b>    | 32 | DMA channel 9 FIFO status           |
| A0020940 | <b>VDMA9 ALTLEN</b>   | 32 | DMA channel 9 alert length          |
| A0020944 | <b>VDMA9 FFSIZE</b>   | 32 | DMA channel 9 FIFO size             |
| A0020A10 | <b>VDMA10 COUNT</b>   | 32 | DMA channel 10 transfer count       |
| A0020A14 | <b>VDMA10 CON</b>     | 32 | DMA channel 10 control              |
| A0020A18 | <b>VDMA10 START</b>   | 32 | DMA channel 10 start register       |
| A0020A1C | <b>VDMA10 INTSTA</b>  | 32 | DMA channel 10 interrupt status     |

|          |                        |    |                                      |
|----------|------------------------|----|--------------------------------------|
| A0020A20 | <b>VDMA10 ACKINT</b>   | 32 | DMA channel 10 interrupt acknowledge |
| A0020A28 | <b>VDMA10 LIMITER</b>  | 32 | DMA channel 10 bandwidth limiter     |
| A0020A2C | <b>VDMA10 PGMAADDR</b> | 32 | DMA channel 10 programmable address  |
| A0020A30 | <b>VDMA10 WRPTR</b>    | 32 | DMA channel 10 write pointer         |
| A0020A34 | <b>VDMA10 RDPTR</b>    | 32 | DMA channel 10 read pointer          |
| A0020A38 | <b>VDMA10 FFCNT</b>    | 32 | DMA channel 10 FIFO count            |
| A0020A3C | <b>VDMA10 FFSTA</b>    | 32 | DMA channel 10 FIFO status           |
| A0020A40 | <b>VDMA10 ALTLEN</b>   | 32 | DMA channel 10 alert length          |
| A0020A44 | <b>VDMA10 FFSIZE</b>   | 32 | DMA channel 10 FIFO size             |
| A0020B10 | <b>VDMA11 COUNT</b>    | 32 | DMA channel 11 transfer count        |
| A0020B14 | <b>VDMA11 CON</b>      | 32 | DMA channel 11 control               |
| A0020B18 | <b>VDMA11 START</b>    | 32 | DMA channel 11 start register        |
| A0020B1C | <b>VDMA11 INTSTA</b>   | 32 | DMA channel 11 interrupt status      |
| A0020B20 | <b>VDMA11 ACKINT</b>   | 32 | DMA channel 11 interrupt acknowledge |
| A0020B28 | <b>VDMA11 LIMITER</b>  | 32 | DMA channel 11 bandwidth limiter     |
| A0020B2C | <b>VDMA11 PGMAADDR</b> | 32 | DMA channel 11 programmable address  |
| A0020B30 | <b>VDMA11 WRPTR</b>    | 32 | DMA channel 11 write pointer         |
| A0020B34 | <b>VDMA11 RDPTR</b>    | 32 | DMA channel 11 read pointer          |
| A0020B38 | <b>VDMA11 FFCNT</b>    | 32 | DMA channel 11 FIFO count            |
| A0020B3C | <b>VDMA11 FFSTA</b>    | 32 | DMA channel 11 FIFO status           |
| A0020B40 | <b>VDMA11 ALTLEN</b>   | 32 | DMA channel 11 alert length          |
| A0020B44 | <b>VDMA11 FFSIZE</b>   | 32 | DMA channel 11 FIFO size             |
| A0020C10 | <b>VDMA12 COUNT</b>    | 32 | DMA channel 12 transfer count        |
| A0020C14 | <b>VDMA12 CON</b>      | 32 | DMA channel 12 control               |
| A0020C18 | <b>VDMA12 START</b>    | 32 | DMA channel 12 start register        |
| A0020C1C | <b>VDMA12 INTSTA</b>   | 32 | DMA channel 12 interrupt status      |
| A0020C20 | <b>VDMA12 ACKINT</b>   | 32 | DMA channel 12 interrupt acknowledge |
| A0020C28 | <b>VDMA12 LIMITER</b>  | 32 | DMA channel 12 bandwidth limiter     |
| A0020C2C | <b>VDMA12 PGMAADDR</b> | 32 | DMA channel 12 programmable address  |
| A0020C30 | <b>VDMA12 WRPTR</b>    | 32 | DMA channel 12 write pointer         |
| A0020C34 | <b>VDMA12 RDPTR</b>    | 32 | DMA channel 12 read pointer          |
| A0020C38 | <b>VDMA12 FFCNT</b>    | 32 | DMA channel 12 FIFO count            |

|          |                       |    |                                      |
|----------|-----------------------|----|--------------------------------------|
| A0020C3C | <u>VDMA12_FFSTA</u>   | 32 | DMA channel 12 FIFO status           |
| A0020C40 | <u>VDMA12_ALTLLEN</u> | 32 | DMA channel 12 alert length          |
| A0020C44 | <u>VDMA12_FFSIZE</u>  | 32 | DMA channel 12 FIFO size             |
| A0020D10 | <u>VDMA13_COUNT</u>   | 32 | DMA channel 13 transfer count        |
| A0020D14 | <u>VDMA13_CON</u>     | 32 | DMA channel 13 control               |
| A0020D18 | <u>VDMA13_START</u>   | 32 | DMA channel 13 start register        |
| A0020D1C | <u>VDMA13_INTSTA</u>  | 32 | DMA channel 13 interrupt status      |
| A0020D20 | <u>VDMA13_ACKINT</u>  | 32 | DMA channel 13 interrupt acknowledge |
| A0020D28 | <u>VDMA13_LIMITER</u> | 32 | DMA channel 13 bandwidth limiter     |
| A0020D2C | <u>VDMA13_PGMADDR</u> | 32 | DMA channel 13 programmable address  |
| A0020D30 | <u>VDMA13_WRPTR</u>   | 32 | DMA channel 13 write pointer         |
| A0020D34 | <u>VDMA13_RDPTR</u>   | 32 | DMA channel 13 read pointer          |
| A0020D38 | <u>VDMA13_FFCNT</u>   | 32 | DMA channel 13 FIFO count            |
| A0020D3C | <u>VDMA13_FFSTA</u>   | 32 | DMA channel 13 FIFO status           |
| A0020D40 | <u>VDMA13_ALTLLEN</u> | 32 | DMA channel 13 alert length          |
| A0020D44 | <u>VDMA13_FFSIZE</u>  | 32 | DMA channel 13 FIFO size             |
| A0020E10 | <u>VDMA14_COUNT</u>   | 32 | DMA channel 14 transfer count        |
| A0020E14 | <u>VDMA14_CON</u>     | 32 | DMA channel 14 control               |
| A0020E18 | <u>VDMA14_START</u>   | 32 | DMA channel 14 start register        |
| A0020E1C | <u>VDMA14_INTSTA</u>  | 32 | DMA channel 14 interrupt status      |
| A0020E20 | <u>VDMA14_ACKINT</u>  | 32 | DMA channel 14 interrupt acknowledge |
| A0020E28 | <u>VDMA14_LIMITER</u> | 32 | DMA channel 14 bandwidth limiter     |
| A0020E2C | <u>VDMA14_PGMADDR</u> | 32 | DMA channel 14 programmable address  |
| A0020E30 | <u>VDMA14_WRPTR</u>   | 32 | DMA channel 14 write pointer         |
| A0020E34 | <u>VDMA14_RDPTR</u>   | 32 | DMA channel 14 read pointer          |
| A0020E38 | <u>VDMA14_FFCNT</u>   | 32 | DMA channel 14 FIFO count            |
| A0020E3C | <u>VDMA14_FFSTA</u>   | 32 | DMA channel 14 FIFO status           |
| A0020E40 | <u>VDMA14_ALTLLEN</u> | 32 | DMA channel 14 alert length          |
| A0020E44 | <u>VDMA14_FFSIZE</u>  | 32 | DMA channel 14 FIFO size             |
| A0020F10 | <u>VDMA15_COUNT</u>   | 32 | DMA channel 15 transfer count        |
| A0020F14 | <u>VDMA15_CON</u>     | 32 | DMA channel 15 control               |
| A0020F18 | <u>VDMA15_START</u>   | 32 | DMA channel 15 start register        |
| A0020F1C | <u>VDMA15_INTSTA</u>  | 32 | DMA channel 15 interrupt status      |

|          |                        |    |                                      |
|----------|------------------------|----|--------------------------------------|
| A0020F20 | <u>VDMA15 ACKINT</u>   | 32 | DMA channel 15 interrupt acknowledge |
| A0020F28 | <u>VDMA15 LIMITER</u>  | 32 | DMA channel 15 bandwidth limiter     |
| A0020F2C | <u>VDMA15 PGMAADDR</u> | 32 | DMA channel 15 programmable address  |
| A0020F30 | <u>VDMA15 WRPTR</u>    | 32 | DMA channel 15 write pointer         |
| A0020F34 | <u>VDMA15 RDPTR</u>    | 32 | DMA channel 15 read pointer          |
| A0020F38 | <u>VDMA15 FFCNT</u>    | 32 | DMA channel 15 FIFO count            |
| A0020F3C | <u>VDMA15 FFSTA</u>    | 32 | DMA channel 15 FIFO status           |
| A0020F40 | <u>VDMA15 ALTLEN</u>   | 32 | DMA channel 15 alert length          |
| A0020F44 | <u>VDMA15 FFSIZE</u>   | 32 | DMA channel 15 FIFO size             |
| A0021010 | <u>VDMA16 COUNT</u>    | 32 | DMA channel 16 transfer count        |
| A0021014 | <u>VDMA16 CON</u>      | 32 | DMA channel 16 control               |
| A0021018 | <u>VDMA16 START</u>    | 32 | DMA channel 16 start register        |
| A002101C | <u>VDMA16 INTSTA</u>   | 32 | DMA channel 16 interrupt status      |
| A0021020 | <u>VDMA16 ACKINT</u>   | 32 | DMA channel 16 interrupt acknowledge |
| A0021028 | <u>VDMA16 LIMITER</u>  | 32 | DMA channel 16 bandwidth limiter     |
| A002102C | <u>VDMA16 PGMAADDR</u> | 32 | DMA channel 16 programmable address  |
| A0021030 | <u>VDMA16 WRPTR</u>    | 32 | DMA channel 16 write pointer         |
| A0021034 | <u>VDMA16 RDPTR</u>    | 32 | DMA channel 16 read pointer          |
| A0021038 | <u>VDMA16 FFCNT</u>    | 32 | DMA channel 16 FIFO count            |
| A002103C | <u>VDMA16 FFSTA</u>    | 32 | DMA channel 16 FIFO status           |
| A0021040 | <u>VDMA16 ALTLEN</u>   | 32 | DMA channel 16 alert length          |
| A0021044 | <u>VDMA16 FFSIZE</u>   | 32 | DMA channel 16 FIFO size             |

| A0020000 DMA_GLBSTA |      |           |      |           |      |           |      |           |      |           |      |           |      |           |     | DMA global status |            |  |  |  |
|---------------------|------|-----------|------|-----------|------|-----------|------|-----------|------|-----------|------|-----------|------|-----------|-----|-------------------|------------|--|--|--|
| Bit                 | 31   | 30        | 29   | 28        | 27   | 26        | 25   | 24        | 23   | 22        | 21   | 20        | 19   | 18        | 17  | 16                | oooooooooo |  |  |  |
| Name                | IT16 | RUN1<br>6 | IT15 | RUN1<br>5 | IT14 | RUN1<br>4 | IT13 | RUN1<br>3 | IT12 | RUN1<br>2 | IT11 | RUN1<br>1 | IT10 | RUN1<br>0 | IT9 | RUN9              |            |  |  |  |
| Type                | RO   | RO        | RO  | RO                |            |  |  |  |
| Reset               | 0    | 0         | 0    | 0         | 0    | 0         | 0    | 0         | 0    | 0         | 0    | 0         | 0    | 0         | 0   | 0                 |            |  |  |  |
| Bit                 | 15   | 14        | 13   | 12        | 11   | 10        | 9    | 8         | 7    | 6         | 5    | 4         | 3    | 2         | 1   | 0                 |            |  |  |  |
| Name                | IT8  | RUN8      | IT7  | RUN7      | IT6  | RUN6      | IT5  | RUN5      | IT4  | RUN4      | IT3  | RUN3      | IT2  | RUN2      | IT1 | RUN1              |            |  |  |  |
| Type                | RO   | RO        | RO  | RO                |            |  |  |  |
| Reset               | 0    | 0         | 0    | 0         | 0    | 0         | 0    | 0         | 0    | 0         | 0    | 0         | 0    | 0         | 0   | 0                 |            |  |  |  |

| Bit(s) | Name  | Description                 |
|--------|-------|-----------------------------|
| 31     | IT16  | Channel 16 interrupt status |
| 30     | RUN16 | Channel 16 running status   |
| 29     | IT15  | Channel 15 interrupt status |

|    |       |                             |
|----|-------|-----------------------------|
| 28 | RUN15 | Channel 15 running status   |
| 27 | IT14  | Channel 14 interrupt status |
| 26 | RUN14 | Channel 14 running status   |
| 25 | IT13  | Channel 13 interrupt status |
| 24 | RUN13 | Channel 13 running status   |
| 23 | IT12  | Channel 12 interrupt status |
| 22 | RUN12 | Channel 12 running status   |
| 21 | IT11  | Channel 11 interrupt status |
| 20 | RUN11 | Channel 11 running status   |
| 19 | IT10  | Channel 10 interrupt status |
| 18 | RUN10 | Channel 10 running status   |
| 17 | IT9   | channel 9 interrupt status  |
| 16 | RUN9  | channel 9 running status    |
| 15 | IT8   | Channel 8 interrupt status  |
| 14 | RUN8  | Channel 8 running status    |
| 13 | IT7   | Channel 7 interrupt status  |
| 12 | RUN7  | Channel 7 running status    |
| 11 | IT6   | Channel 6 interrupt status  |
| 10 | RUN6  | Channel 6 running status    |
| 9  | IT5   | Channel 5 interrupt status  |
| 8  | RUN5  | Channel 5 running status    |
| 7  | IT4   | Channel 4 interrupt status  |
| 6  | RUN4  | Channel 4 running status    |
| 5  | IT3   | Channel 3 interrupt status  |
| 4  | RUN3  | Channel 3 running status    |
| 3  | IT2   | Channel 2 interrupt status  |
| 2  | RUN2  | Channel 2 running status    |
| 1  | IT1   | Channel 1 interrupt status  |
| 0  | RUN1  | Channel 1 running status    |

**A0020008 DMA GLB CPUo CFG DMA top hierarchy interrupt config 00000000**

| Bit   | 31                       | 30                 | 29                 | 28                 | 27                 | 26                 | 25                | 24                | 23                | 22                | 21                | 20                | 19                | 18                | 17                | 16 |
|-------|--------------------------|--------------------|--------------------|--------------------|--------------------|--------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|----|
| Name  |                          |                    |                    |                    |                    |                    |                   |                   |                   |                   |                   |                   |                   |                   |                   |    |
| Type  |                          |                    |                    |                    |                    |                    |                   |                   |                   |                   |                   |                   |                   |                   |                   |    |
| Reset |                          |                    |                    |                    |                    |                    |                   |                   |                   |                   |                   |                   |                   |                   |                   |    |
| Bit   | 15                       | 14                 | 13                 | 12                 | 11                 | 10                 | 9                 | 8                 | 7                 | 6                 | 5                 | 4                 | 3                 | 2                 | 1                 | 0  |
| Name  | CPUo<br>_CFG<br>16<br>15 | CPUo<br>_CFG<br>14 | CPUo<br>_CFG<br>13 | CPUo<br>_CFG<br>12 | CPUo<br>_CFG<br>11 | CPUo<br>_CFG<br>10 | CPUo<br>_CFG<br>9 | CPUo<br>_CFG<br>8 | CPUo<br>_CFG<br>7 | CPUo<br>_CFG<br>6 | CPUo<br>_CFG<br>5 | CPUo<br>_CFG<br>4 | CPUo<br>_CFG<br>3 | CPUo<br>_CFG<br>2 | CPUo<br>_CFG<br>1 |    |
| Type  | RW                       | RW                 | RW                 | RW                 | RW                 | RW                 | RW                | RW                | RW                | RW                | RW                | RW                | RW                | RW                | RW                | RW |
| Reset | 0                        | 0                  | 0                  | 0                  | 0                  | 0                  | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0                 | 0  |

| Bit(s) | Name       | Description                                |
|--------|------------|--------------------------------------------|
| 15     | CPUo_CFG16 | Channel 16 CPUo interrupt enable configure |

---

|    |            |                                            |
|----|------------|--------------------------------------------|
| 14 | CPUo_CFG15 | Channel 15 CPUo interrupt enable configure |
| 13 | CPUo_CFG14 | Channel 14 CPUo interrupt enable configure |
| 12 | CPUo_CFG13 | Channel 13 CPUo interrupt enable configure |
| 11 | CPUo_CFG12 | Channel 12 CPUo interrupt enable configure |
| 10 | CPUo_CFG11 | Channel 11 CPUo interrupt enable configure |
| 9  | CPUo_CFG10 | Channel 10 CPUo interrupt enable configure |
| 8  | CPUo_CFG9  | Channel 9 CPUo interrupt enable configure  |
| 7  | CPUo_CFG8  | Channel 8 CPUo interrupt enable configure  |
| 6  | CPUo_CFG7  | Channel 7 CPUo interrupt enable configure  |
| 5  | CPUo_CFG6  | Channel 6 CPUo interrupt enable configure  |
| 4  | CPUo_CFG5  | Channel 5 CPUo interrupt enable configure  |
| 3  | CPUo_CFG4  | Channel 4 CPUo interrupt enable configure  |
| 2  | CPUo_CFG3  | Channel 3 CPUo interrupt enable configure  |
| 1  | CPUo_CFG2  | Channel 2 CPUo interrupt enable configure  |
| 0  | CPUo_CFG1  | Channel 1 CPUo interrupt enable configure  |

---

**A002000C DMA GLB CPUo SET DMA top hierarchy interrupt set 00000000**

| Bit   | 31         | 30         | 29         | 28         | 27         | 26         | 25         | 24        | 23        | 22        | 21        | 20        | 19        | 18        | 17        | 16        |
|-------|------------|------------|------------|------------|------------|------------|------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|
| Name  |            |            |            |            |            |            |            |           |           |           |           |           |           |           |           |           |
| Type  |            |            |            |            |            |            |            |           |           |           |           |           |           |           |           |           |
| Reset |            |            |            |            |            |            |            |           |           |           |           |           |           |           |           |           |
| Bit   | 15         | 14         | 13         | 12         | 11         | 10         | 9          | 8         | 7         | 6         | 5         | 4         | 3         | 2         | 1         | 0         |
| Name  | CPUo_SET16 | CPUo_SET15 | CPUo_SET14 | CPUo_SET13 | CPUo_SET12 | CPUo_SET11 | CPUo_SET10 | CPUo_SET9 | CPUo_SET8 | CPUo_SET7 | CPUo_SET6 | CPUo_SET5 | CPUo_SET4 | CPUo_SET3 | CPUo_SET2 | CPUo_SET1 |
| Type  | WO         | WO        | WO        | WO        | WO        | WO        | WO        | WO        | WO        | WO        |
| Reset | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0         | 0         | 0         | 0         | 0         | 0         | 0         | 0         | 0         |

---

| Bit(s) | Name       | Description                          |
|--------|------------|--------------------------------------|
| 15     | CPUo_SET16 | Channel 16 CPUo interrupt enable set |
| 14     | CPUo_SET15 | Channel 15 CPUo interrupt enable set |
| 13     | CPUo_SET14 | Channel 14 CPUo interrupt enable set |
| 12     | CPUo_SET13 | Channel 13 CPUo interrupt enable set |
| 11     | CPUo_SET12 | Channel 12 CPUo interrupt enable set |
| 10     | CPUo_SET11 | Channel 11 CPUo interrupt enable set |
| 9      | CPUo_SET10 | Channel 10 CPUo interrupt enable set |
| 8      | CPUo_SET9  | Channel 9 CPUo interrupt enable set  |
| 7      | CPUo_SET8  | Channel 8 CPUo interrupt enable set  |
| 6      | CPUo_SET7  | Channel 7 CPUo interrupt enable set  |
| 5      | CPUo_SET6  | Channel 6 CPUo interrupt enable set  |
| 4      | CPUo_SET5  | Channel 5 CPUo interrupt enable set  |
| 3      | CPUo_SET4  | Channel 4 CPUo interrupt enable set  |
| 2      | CPUo_SET3  | Channel 3 CPUo interrupt enable set  |
| 1      | CPUo_SET2  | Channel 2 CPUo interrupt enable set  |
| 0      | CPUo_SET1  | Channel 1 CPUo interrupt enable set  |

---

| <b>A0020010 DMA GLB CPU0 CLR</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>DMA top hierarchy interrupt clr</b> |             |            |            |            |            |            |            |            |           |           |           |           |           |           |           | <b>00000000</b> |           |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|----------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------------------------------|-------------|------------|------------|------------|------------|------------|------------|------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------------|-----------|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| <b>Bit</b>                       | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                                     | <b>Name</b> |            |            |            |            |            |            |            |           |           |           |           |           |           |           |                 |           |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                        |             |            |            |            |            |            |            |            |           |           |           |           |           |           |           |                 |           |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| <b>Reset</b>                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                        |             |            |            |            |            |            |            |            |           |           |           |           |           |           |           |                 |           |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| <b>Bit</b>                       | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                                      | <b>Name</b> | CPUo_CLR16 | CPUo_CLR15 | CPUo_CLR14 | CPUo_CLR13 | CPUo_CLR12 | CPUo_CLR11 | CPUo_CLR10 | CPUo_CLR9 | CPUo_CLR8 | CPUo_CLR7 | CPUo_CLR6 | CPUo_CLR5 | CPUo_CLR4 | CPUo_CLR3 | CPUo_CLR2       | CPUo_CLR1 | <b>Type</b> | WO | <b>Reset</b> | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                     |
|---------------|-------------|----------------------------------------|
| 15            | CPUo_CLR16  | Channel 16 CPUo interrupt enable clear |
| 14            | CPUo_CLR15  | Channel 15 CPUo interrupt enable clear |
| 13            | CPUo_CLR14  | Channel 14 CPUo interrupt enable clear |
| 12            | CPUo_CLR13  | Channel 13 CPUo interrupt enable clear |
| 11            | CPUo_CLR12  | Channel 12 CPUo interrupt enable clear |
| 10            | CPUo_CLR11  | Channel 11 CPUo interrupt enable clear |
| 9             | CPUo_CLR10  | Channel 10 CPUo interrupt enable clear |
| 8             | CPUo_CLR9   | Channel 9 CPUo interrupt enable clear  |
| 7             | CPUo_CLR8   | Channel 8 CPUo interrupt enable clear  |
| 6             | CPUo_CLR7   | Channel 7 CPUo interrupt enable clear  |
| 5             | CPUo_CLR6   | Channel 6 CPUo interrupt enable clear  |
| 4             | CPUo_CLR5   | Channel 5 CPUo interrupt enable clear  |
| 3             | CPUo_CLR4   | Channel 4 CPUo interrupt enable clear  |
| 2             | CPUo_CLR3   | Channel 3 CPUo interrupt enable clear  |
| 1             | CPUo_CLR2   | Channel 2 CPUo interrupt enable clear  |
| 0             | CPUo_CLR1   | Channel 1 CPUo interrupt enable clear  |

| <b>A0020028 DMA GLBLIMITER</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>DMA global bandwidth limiter register 00000000</b> |              |                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |             |           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |              |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|--------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------------------------------------------|--------------|----------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-------------|-----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--------------|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Bit</b>                     | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                                                    | <b>Name</b>  |                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |             |           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |              |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                                       | <b>Reset</b> |                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |             |           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |              |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Bit</b>                     | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                                                     | <b>Name</b>  | <b>LIMITER</b> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>Type</b> | <b>WO</b> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>Reset</b> | 0 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                                                                                                                                                                                                                    |
|---------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0           | LIMITER     | <b>Utilization suppression</b><br>This register suppresses the bus utilization of the DMA channel.<br>From 0 to 255. 0 means no limitation, 255 means totally banned.<br>All other values indicate bus access permission for every (4 x n) AHB clock. |

| <b>A0020020 DMA GLB SWRST</b> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>DMA global software reset</b> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>00000000</b> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|----------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-----------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
|-------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|----------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-----------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|

|              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|
| <b>Bit</b>   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16              |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0               |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>SW_RESET</b> |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW              |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0               |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                 |
|---------------|-------------|----------------------------------------------------|
| 0             | SW_RESET    | Software reset<br>Write 1 to the register to reset |

| <b>A0020040 DMA_GLB_BUSY DMA global busy status 00000000</b> |       |       |       |       |       |       |       |      |      |      |      |      |      |      |      |      |
|--------------------------------------------------------------|-------|-------|-------|-------|-------|-------|-------|------|------|------|------|------|------|------|------|------|
| <b>Bit</b>                                                   | 31    | 30    | 29    | 28    | 27    | 26    | 25    | 24   | 23   | 22   | 21   | 20   | 19   | 18   | 17   | 16   |
| <b>Name</b>                                                  |       |       |       |       |       |       |       |      |      |      |      |      |      |      |      |      |
| <b>Type</b>                                                  |       |       |       |       |       |       |       |      |      |      |      |      |      |      |      |      |
| <b>Reset</b>                                                 |       |       |       |       |       |       |       |      |      |      |      |      |      |      |      |      |
| <b>Bit</b>                                                   | 15    | 14    | 13    | 12    | 11    | 10    | 9     | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| <b>Name</b>                                                  | RUN16 | RUN15 | RUN14 | RUN13 | RUN12 | RUN11 | RUN10 | RUN9 | RUN8 | RUN7 | RUN6 | RUN5 | RUN4 | RUN3 | RUN2 | RUN1 |
| <b>Type</b>                                                  | RW    | RW   | RW   | RW   | RW   | RW   | RW   | RW   | RW   | RW   |
| <b>Reset</b>                                                 | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>        |
|---------------|-------------|---------------------------|
| 15            | RUN16       | Channel 16 running status |
| 14            | RUN15       | Channel 15 running status |
| 13            | RUN14       | Channel 14 running status |
| 12            | RUN13       | Channel 13 running status |
| 11            | RUN12       | Channel 12 running status |
| 10            | RUN11       | Channel 11 running status |
| 9             | RUN10       | Channel 10 running status |
| 8             | RUN9        | Channel 9 running status  |
| 7             | RUN8        | Channel 8 running status  |
| 6             | RUN7        | Channel 7 running status  |
| 5             | RUN6        | Channel 6 running status  |
| 4             | RUN5        | Channel 5 running status  |
| 3             | RUN4        | Channel 4 running status  |
| 2             | RUN3        | Channel 3 running status  |
| 1             | RUN2        | Channel 2 running status  |
| 0             | RUN1        | Channel 1 running status  |

| <b>A0020044 DMA_GLB_INTR DMA global interrupt status 00000000</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Bit</b>                                                        | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b>                                                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                                                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                                                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit   | 15   | 14   | 13   | 12   | 11   | 10   | 9    | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-------|------|------|------|------|------|------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| Name  | IT16 | IT15 | IT14 | IT13 | IT12 | IT11 | IT10 | IT9 | IT8 | IT7 | IT6 | IT5 | IT4 | IT3 | IT2 | IT1 |
| Type  | RW   | RW  | RW  | RW  | RW  | RW  | RW  | RW  | RW  | RW  |
| Reset | o    | o    | o    | o    | o    | o    | o    | o   | o   | o   | o   | o   | o   | o   | o   | o   |

| Bit(s) | Name | Description                 |
|--------|------|-----------------------------|
| 15     | IT16 | Channel 16 interrupt status |
| 14     | IT15 | Channel 15 interrupt status |
| 13     | IT14 | Channel 14 interrupt status |
| 12     | IT13 | Channel 13 interrupt status |
| 11     | IT12 | Channel 12 interrupt status |
| 10     | IT11 | Channel 11 interrupt status |
| 9      | IT10 | Channel 10 interrupt status |
| 8      | IT9  | Channel 9 interrupt status  |
| 7      | IT8  | Channel 8 interrupt status  |
| 6      | IT7  | Channel 7 interrupt status  |
| 5      | IT6  | Channel 6 interrupt status  |
| 4      | IT5  | Channel 5 interrupt status  |
| 3      | IT4  | Channel 4 interrupt status  |
| 2      | IT3  | Channel 3 interrupt status  |
| 1      | IT2  | Channel 2 interrupt status  |
| 0      | IT1  | Channel 1 interrupt status  |

| A0020100 <u>GDMA1_SRC</u> DMA channel 1 source address                          000000000 |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------------------------------------------------------------------------------------------|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit Name                                                                                  | 31  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| SRC                                                                                       |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                                                                                      | RW  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset                                                                                     | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit                                                                                       | 15  | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name                                                                                      | SRC |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                                                                                      | RW  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset                                                                                     | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name | Description                                                                                                                                                                                                                                                                                                                                                                                      |
|--------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | SRC  | <p><b>GDMA source address</b></p> <p>This register contains the base or current source address that the DMA channel is currently operating on.</p> <ul style="list-style-type: none"> <li>Writing into this register specifies the base address of the transfer source for a DMA channel.</li> <li>Reading this register will return the address value from which the DMA is reading.</li> </ul> |

| A0020104 <u>GDMA1_DST</u> DMA channel 1 destination address                          000000000 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------------------------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit Name                                                                                       | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| DST                                                                                            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

|        |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|-----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| e      |     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type   | RW  |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Rese t | 0   | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Bit    | 15  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name   | DST |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type   | RW  |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Rese t | 0   | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| Bit(s) | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | DST  | <p><b>GDMA destination address</b></p> <p>This register contains the base or current destination address that the DMA channel is currently operating on.</p> <ul style="list-style-type: none"> <li>Writing into this register specifies the base address of the transfer destination for a DMA channel.</li> <li>Reading this register will return the address value to which the DMA is writing.</li> </ul> |
|        |      |                                                                                                                                                                                                                                                                                                                                                                                                               |

|          |            |                                  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----------|------------|----------------------------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|
| A0020108 | GDMA1_WPPT | DMA channel 1 wrap point address | oooooooooooo |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit      | 31         | 30                               | 29           | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|          |            |                                  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Name     |            |                                  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type     |            |                                  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t   |            |                                  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit      | 15         | 14                               | 13           | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|          |            |                                  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Name     | WPPT       |                                  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type     | RW         |                                  |              |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t   | 0          | 0                                | 0            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0   | WPPT | <p><b>Transfer counts before jump</b></p> <p>This register specifies the transfer count required to perform before the jump point. This can be used to support ring buffer or double buffer memory access. To enable the wrap function, two control bits, WPEN and WPSD in the DMA control register must be programmed. If the transfer counter in the DMA engine matches this value, an address jump will occur, and the next address will be the address specified in GDMAn_WPTO. To enable this function, set up WPEN in GDMAn_CON.</p> <p>Note, that the total size of data specified in the wrap point count in a DMA channel is determined by WPPT together with SIZE in GDMAn_CON, such as WPPT x SIZE.</p> |
|        |      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

|          |            |                               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----------|------------|-------------------------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|
| A002010C | GDMA1_WPTO | DMA channel 1 wrap to address | oooooooooooo |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit      | 31         | 30                            | 29           | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|          |            |                               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Name     | WPTO       |                               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type     | RW         |                               |              |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t   | 0          | 0                             | 0            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                                                                                                                                                                                                                                 |
|---------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0          | WPTO        | <p><b>Jump address</b></p> <p>This register specifies the destination address of a given DMA transfer to support ring buffer or double buffer memory access. To enable the wrap function, set the two control bits, WPEN and WPSD in the DMA control register.</p> |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0          | COUNT       | <p><b>Number of transfers</b></p> <p>This register specifies the number of transfers of the DMA channel is required to perform. Upon completion, the DMA channel generates an interrupt request to the processor while ITEN in GDMAn_CON is set to 1.</p> <ul style="list-style-type: none"> <li>• Note that the total size of transfer data is determined by LEN and SIZE in GDMAn_CON, such as LEN x SIZE.</li> </ul> |

| DMA channel 1 control |         |    |    |    |    |    |    | 00000000    |    |    |    |    |           |       |       |       |
|-----------------------|---------|----|----|----|----|----|----|-------------|----|----|----|----|-----------|-------|-------|-------|
| Bit Name              | 31      | 30 | 29 | 28 | 27 | 26 | 25 | 24<br>ITE N | 23 | 22 | 21 | 20 | 19        | 18    | 17    | 16    |
|                       | SETTING |    |    |    |    |    |    |             | RW |    |    |    |           |       |       |       |
| Type                  |         |    |    |    |    |    |    | RW          |    |    |    |    | RW        |       |       |       |
| Rese t                |         |    |    |    |    |    |    |             |    |    |    |    | BURST     |       | DR EQ |       |
| Bit                   | 15      | 14 | 13 | 12 | 11 | 10 | 9  | 8           | 7  | 6  | 5  | 4  | 0         | 0     | 0     | 0     |
| Name                  |         |    |    |    |    |    |    | SIZE        |    |    |    |    | DIRECTION |       |       |       |
| Type                  |         |    |    |    |    |    |    | RW          |    |    |    |    | RW        |       |       |       |
| Rese t                |         |    |    |    |    |    |    | 0           | 0  |    |    |    | WP EN     | WP SD | DIN C | SIN C |
|                       |         |    |    |    |    |    |    |             |    |    |    |    | 0         | 0     | 0     | 0     |

| Bit(s) | Name      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24     | ITEN      | <b>Enable DMA transfer completion interrupt</b> <ul style="list-style-type: none"> <li>• 0: Disable</li> <li>• 1: Enable</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 19:16  | SETTING   | <p><b>[16] Throttle and handshake control for DMA transfer.</b><br/>The DMA master is able to throttle down the transfer rate by request-grant handshake process.</p> <p><b>[19:18] Transfer type.</b><br/>The burst-type transfers have better bus efficiency. Apply this type for larger data movement.<br/>Note that the burst-type transfer will not stop until all of the beats in a burst are complete or the transfer length is reached. The transfer type is restricted by SIZE. If SIZE is oob, i.e. byte transfer, all four transfer types can be used. If SIZE is o1b (half-word transfer), 16-beat incrementing burst cannot be used. If SIZE is 10b, i.e. word transfer, only single and 4-beat incrementing burst can be used.</p> <ul style="list-style-type: none"> <li>• [16] DREQ: 0, No throttle control during DMA transfer or transfers occurred only between memories; 1, Hardware handshake management.</li> <li>• [19:18] BURST: 00 = Single; 01 = Reserved; 10 = 4-beat incrementing burst; 11 = Reserved;</li> </ul>                           |
| 9:8    | SIZE      | <p><b>Data size within the confine of a bus cycle per transfer.</b><br/>These bits confine the data transfer size between the source and destination to the specified value for individual bus cycle. The size is in bytes and the maximum value is 4 bytes. It is mainly decided by the data width of a DMA master.</p> <ul style="list-style-type: none"> <li>• 00: Byte transfer/1 byte</li> <li>• 01: Half-word transfer/2 bytes</li> <li>• 10: Word transfer/4 bytes</li> <li>• 11: Reserved</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 3:0    | DIRECTION | <p><b>[0] Incremental source address.</b><br/>The source addresses increments after each transfer. If SIZE is in bytes, the source address will increase by 1, if it's in half-word, it will increase by 2 and if word, increase by 4.</p> <p><b>[1] Incremental destination address.</b><br/>The destination address increments after each transfer. If SIZE is in bytes, the destination address will increase by 1, if it's in half-word, it will increase by 2 and if word, increase by 4.</p> <p><b>[2] Wrap select</b><br/>The side using address-wrapping function. Only one side of a DMA channel can activate the address-wrapping function at a time.</p> <p><b>[3] Wrap enable</b><br/>Address-wrapping for ring buffer and double buffer. The next address of DMA jumps to WRAP TO address when the current address matches WRAP POINT count.</p> <ul style="list-style-type: none"> <li>• [0]SINC:0=Disable; 1=Enable</li> <li>• [1]DINC:0=Disable; 1=Enable</li> <li>• [2]WPSD: 0=Address-wrapping on source; 1=Address-wrapping on destination</li> </ul> |

- [3]WPEN: 0=Disable; 1=Enable

| <b>A0020118 GDMA1 START</b> |     |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>DMA channel 1 start</b> |        |     |    |    |    |    |    |    |   |   |   |   |   |   | <b>oooooooooooo</b> |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
|-----------------------------|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------------------|--------|-----|----|----|----|----|----|----|---|---|---|---|---|---|---------------------|---|---|---|--|--|--|--|--|--|--|--|--|--|--|
| Bit                         | 31  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17                         | 16     | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3                   | 2 | 1 | 0 |  |  |  |  |  |  |  |  |  |  |  |
| Name                        | STR |    |    |    |    |    |    |    |    |    |    |    |    |    |                            | Name   | RW  |    |    |    |    |    |    |   |   |   |   |   |   |                     |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
| Type                        |     |    |    |    |    |    |    |    |    |    |    |    |    |    |                            | Type   | o   |    |    |    |    |    |    |   |   |   |   |   |   |                     |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
| Rese t                      |     |    |    |    |    |    |    |    |    |    |    |    |    |    |                            | Rese t |     |    |    |    |    |    |    |   |   |   |   |   |   |                     |   |   |   |  |  |  |  |  |  |  |  |  |  |  |

| Bit(s) | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15     | STR  | <b>Start control for a DMA channel</b><br>This register controls the activity of a DMA channel. Note, that prior to setting STR to 1, all the register settings should be configured. Once STR is set to 1, the hardware will not clear it automatically no matter the DMA channel accomplishes the DMA transfer or not. In other words, the value of STR stays at 1 regardless of the completion of the DMA transfer. Therefore, the software program should reset STR to 0 before restarting another DMA transfer. If this bit is cleared to 0 when DMA transfer is active, the software should poll RUNn in DMA_GLBSTA after this bit is cleared to ensure the current DMA transfer is terminated by the DMA engine. |
|        |      | <ul style="list-style-type: none"> <li>• 0: The DMA channel is stopped.</li> <li>• 1: The DMA channel is started and running.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

| <b>A002011C GDMA1 INTSTA</b> |     |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>DMA channel 1 interrupt status</b> |        |     |    |    |    |    |    |    |   |   |   |   |   |   | <b>oooooooooooo</b> |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
|------------------------------|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------------------------|--------|-----|----|----|----|----|----|----|---|---|---|---|---|---|---------------------|---|---|---|--|--|--|--|--|--|--|--|--|--|--|
| Bit                          | 31  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17                                    | 16     | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3                   | 2 | 1 | 0 |  |  |  |  |  |  |  |  |  |  |  |
| Name                         | INT |    |    |    |    |    |    |    |    |    |    |    |    |    |                                       | Name   | RW  |    |    |    |    |    |    |   |   |   |   |   |   |                     |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
| Type                         |     |    |    |    |    |    |    |    |    |    |    |    |    |    |                                       | Type   | o   |    |    |    |    |    |    |   |   |   |   |   |   |                     |   |   |   |  |  |  |  |  |  |  |  |  |  |  |
| Rese t                       |     |    |    |    |    |    |    |    |    |    |    |    |    |    |                                       | Rese t |     |    |    |    |    |    |    |   |   |   |   |   |   |                     |   |   |   |  |  |  |  |  |  |  |  |  |  |  |

| Bit(s) | Name | Description                                                                                                                                                                                                 |
|--------|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15     | INT  | <b>Interrupt status for DMA channel</b><br><ul style="list-style-type: none"> <li>• 0: No interrupt request is generated.</li> <li>• 1: An interrupt request is pending and waiting for service.</li> </ul> |
|        |      |                                                                                                                                                                                                             |

**A0020120 GDMA1 ACKINT**      **DMA channel 1 interrupt acknowledge** **oooooooooooo**

|                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Bit Name</b> | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Type</b>     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Bit</b>      | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>     | AC | K  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>     | WO |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>    | 0  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                                                                                                                                                            |
|---------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15            | ACK         | <b>Interrupt acknowledge for the DMA channel</b> <ul style="list-style-type: none"> <li>• 0: No effect</li> <li>• 1: Interrupt request is acknowledged and should be relinquished.</li> </ul> |
|               |             |                                                                                                                                                                                               |

| <b>A0020124 GDMA1 RLCT</b>                                |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-----------------------------------------------------------|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>DMA channel 1 remaining length of current transfer</b> |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Bit Name</b>                                           | 31          | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Type</b>                                               |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                                              |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Bit</b>                                                | 15          | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>                                               | <b>RLCT</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                                               | <b>RO</b>   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                                              | 0           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                                                                                                                             |
|---------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0          | RLCT        | <b>This register is to reflect the remaining length of current transfer (RLCT).</b><br>Note that this value is the transfer count, not the transfer data size. |
|               |             |                                                                                                                                                                |

| <b>A0020128 GDMA1 LIMITER</b>          |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----------------------------------------|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>DMA channel 1 bandwidth limiter</b> |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Bit Name</b>                        | 31             | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Type</b>                            |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                           |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Bit</b>                             | 15             | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>                            | <b>LIMITER</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                            | <b>RW</b>      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                           | 0              | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name    | Description                                                                                                                                                                                                                       |
|--------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0    | LIMITER | <b>Utilization Suppression</b><br>This register suppresses the bus utilization of the DMA channel. From 0 to 255. 0 means no limitation, 255 means totally banned, and others mean bus access permission every (4 x n) AHB clock. |

| A0020208 PDMA2 WPPT |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    | DMA channel 2 wrap point address |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | oooooooooooo |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---------------------|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Bit                 | 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Bit Name            |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type                |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reset               |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Bit                 | 15   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name                | WPPT |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type                | RW   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reset               | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bit(s) | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0   | WPPT | <b>Transfer counts before jump</b><br>This register specifies the transfer count required to perform before the jump point. This can be used to support ring buffer or double buffer memory access. To enable the wrap function, two control bits, WPEN and WPSD in the DMA control register must be programmed. If the transfer counter in the DMA engine matches this value, an address jump will occur, and the next address will be the address specified in GDMAn_WPTO. To enable this function, set up WPEN in GDMAn_CON. |

Note, that the total size of data specified in the wrap point count in a DMA channel is determined by WPPT together with SIZE in GDMAn\_CON, such as WPPT x SIZE.

| A002020C PDMA2 WPTO |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    | DMA channel 2 wrap to address |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | oooooooooooo |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---------------------|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Bit                 | 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Bit Name            | WPTO |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type                | RW   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reset               | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Bit                 | 15   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name                | WPTO |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type                | RW   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reset               | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bit(s) | Name | Description                                                                                                                                                                                                                                                     |
|--------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | WPTO | <b>Jump address</b><br>This register specifies the address of the jump destination of a given DMA transfer to support ring buffer or double buffer memory access. To enable this function, set the two control bits, WPEN and WPSD in the DMA control register. |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                         |
|---------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0          | COUNT       | <p><b>Number of transfers</b></p> <p>This register specifies the number of transfers of the DMA channel is required to perform. Upon completion, the DMA channel generates an interrupt request to the processor while ITEN in GDMAn_CON is set to 1.</p> <p>Note that the total size of transfer data is determined by LEN and SIZE in GDMAN_CON, such as LEN x SIZE.</p> |

| Aoo20214 PDMA2 CON |    |    |    |    |    |    |      | DMA channel 2 control |       |    |    |    |           |         |       | oooooooo |       |  |  |
|--------------------|----|----|----|----|----|----|------|-----------------------|-------|----|----|----|-----------|---------|-------|----------|-------|--|--|
| Bit Name           | 31 | 30 | 29 | 28 | 27 | 26 | 25   | 24                    | ITE N | 23 | 22 | 21 | 20        | 19      | 18    | 17       | 16    |  |  |
|                    |    |    |    |    |    |    |      |                       |       |    |    |    |           | SETTING |       |          |       |  |  |
| Type               |    |    |    |    |    |    |      | RW                    |       |    |    |    |           | RW      |       |          |       |  |  |
| Reset              |    |    |    |    |    |    |      | 0                     |       |    |    |    |           | BURST   |       | B2 W     | DR EQ |  |  |
| Bit                | 15 | 14 | 13 | 12 | 11 | 10 | 9    | 8                     | 7     | 6  | 5  | 4  | 3         | 2       | 1     | 0        |       |  |  |
| Name               |    |    |    |    |    |    | SIZE |                       |       |    |    |    | DIRECTION |         |       |          |       |  |  |
| Type               |    |    |    |    |    |    | RW   |                       |       |    |    |    | RW        |         |       |          |       |  |  |
| Reset              |    |    |    |    |    |    | 0    | 0                     |       |    |    |    | DIR       | WP EN   | WP SD | DIN C    | SIN C |  |  |
|                    |    |    |    |    |    |    |      |                       |       |    |    |    | 0         | 0       | 0     | 0        | 0     |  |  |

| Bit(s) | Name    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24     | ITEN    | <b>Enable DMA transfer completion interrupt</b> <ul style="list-style-type: none"> <li>• 0: Disable</li> <li>• 1: Enable</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 19:16  | SETTING | <p><b>[16] Throttle and handshake control for DMA transfer.</b><br/>The DMA master is able to throttle down the transfer rate by request-grant handshake process.</p> <p><b>[17] Byte to word</b><br/>Word to byte or byte to word transfer for the applications of transferring non-word-aligned-address data to word-aligned-address data. Note that BURST is set to 4-beat burst this function is enabled, and the SIZE is set to byte.</p> <p><b>[19:18] Transfer type.</b><br/>The burst-type transfers have better bus efficiency. Apply this type</p> |

9:8

SIZE

for mass data movement.

Note that the burst-type transfer will not stop until all of the beats in a burst are complete or the transfer length is reached. The transfer type is restricted by SIZE. If SIZE is oob, i.e. byte transfer, all four transfer types can be used. If SIZE is o1b (half-word transfer), 16-beat incrementing burst cannot be used. If SIZE is 10b, i.e. word transfer, only single and 4-beat incrementing burst can be used.

- [16] DREQ: 0, No throttle control during DMA transfer or transfers occurred only between memories; 1, Hardware handshake management.
- [17]B2W: 0=Disable; 1=Enable
- [19:18] BURST: 00 = Single; 01 = Reserved; 10 = 4-beat incrementing burst; 11 = Reserved;

4:0

DIRECTION

#### **Data size within the confine of a bus cycle per transfer.**

These bits confine the data transfer size between the source and destination to the specified value for individual bus cycle. The size is in bytes and the maximum value is 4 bytes. It is mainly decided by the data width of a DMA master.

- 00: Byte transfer/1 byte
- 01: Half-word transfer/2 bytes
- 10: Word transfer/4 bytes
- 11: Reserved

#### **[0] Incremental source address.**

The source addresses increments after each transfer. If SIZE is in bytes, the source address will increase by 1, if it's in half-word, it will increase by 2 and if word, increase by 4.

#### **[1] Incremental destination address.**

The destination address increments after each transfer. If SIZE is in bytes, the destination address will increase by 1, if it's in half-word, it will increase by 2 and if word, increase by 4.

#### **[2] Wrap select**

The side using address-wrapping function. Only one side of a DMA channel can activate the address-wrapping function at a time.

#### **[3] Wrap enable**

Address-wrapping for ring buffer and double buffer. The next address of DMA jumps to WRAP TO address when the current address matches WRAP POINT count.

- [0]SINC:0=Disable; 1=Enable
- [1]DINC:0=Disable; 1=Enable
- [2]WPSD: 0=Address-wrapping on source; 1=Address-wrapping on destination
- [3]WPEN: 0=Disable; 1=Enable
- [4]DIR: 0=peripheral TX; 1=peripheral RX

**A0020218 PDMA2 START****DMA channel 2 start****oooooooo**

| Bit Name | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Type     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit(s) | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|--------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15     | STR  | <p><b>Start control for a DMA channel</b></p> <p>This register controls the activity of a DMA channel. Note that prior to setting STR to 1, all the register settings should be configured. Once STR is set to 1, the hardware will not clear it automatically no matter the DMA channel accomplishes the DMA transfer or not. In other words, the value of STR stays at 1 regardless of the completion of the DMA transfer. Therefore, the software program should reset STR to 0 before restarting another DMA transfer. If this bit is cleared to 0 when DMA transfer is active, the software should poll RUNn in DMA_GLBSTA after this bit is cleared to ensure the current DMA transfer is terminated by the DMA engine.</p> <ul style="list-style-type: none"> <li>• 0: The DMA channel is stopped.</li> <li>• 1: The DMA channel is started and running.</li> </ul> |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                                                                                                                                                                           |
|---------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15            | INT         | <p><b>Interrupt status for DMA channel</b></p> <ul style="list-style-type: none"> <li>o: No interrupt request is generated.</li> <li>1: One interrupt request is pending and waiting for service.</li> </ul> |

|        |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|--------|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Rese t | 0 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|--------|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|

| Bit(s) | Name | Description                                                                                                                                  |
|--------|------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 15     | ACK  | <b>Interrupt acknowledgement for the DMA channel</b>                                                                                         |
|        |      | <ul style="list-style-type: none"> <li>• 0: No effect</li> <li>• 1: Interrupt request is acknowledged and should be relinquished.</li> </ul> |

**A0020224 PDMA2 RLCT** DMA channel 2 remaining length of current transfer **oooooooooooo**

|          |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----------|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit Name | 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Type     |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t   |      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit      | 15   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name     | RLCT |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type     | RO   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t   | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s)                                                              | Name | Description                                                                         |
|---------------------------------------------------------------------|------|-------------------------------------------------------------------------------------|
| 15:0                                                                | RLCT | <b>This register is to reflect the remaining length of current transfer (RLCT).</b> |
| Note that this value is transfer count, not the transfer data size. |      |                                                                                     |

**A0020228 PDMA2 LIMITER** DMA channel 2 bandwidth limiter **oooooooooooo**

|          |         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----------|---------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit Name | 31      | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Type     |         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t   |         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit      | 15      | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name     | LIMITER |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type     | RW      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t   |         |    |    |    |    |    |    |    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s)                                                                                                                                                                                          | Name    | Description                    |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|--------------------------------|
| 7:0                                                                                                                                                                                             | LIMITER | <b>Utilization Suppression</b> |
| This register suppresses the bus utilization of the DMA channel. From 0 to 255. 0 means no limitation, 255 means totally banned, and others mean bus access permission every (4 x n) AHB clock. |         |                                |

**A002022C PDMA2 PGMADDR** DMA channel 2 programmable address **oooooooooooo**

|          |         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----------|---------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit Name | 31      | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Type     | PGMADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t   |         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                                                                                                                                                                                                                                               |
|---------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0          | PGMADDR     | <p><b>PDMA programmable address.</b></p> <p>The above registers specify the address for a half-size DMA channel. This address represents the source address if DIR in DMA_CON is set to 0 and represents the destination address if DIR in PDMA<sub>n</sub>_CON is set to 1.</p> |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0          | COUNT       | <p><b>FIFO threshold</b></p> <p>For virtual FIFO DMA, this register is used to configure the RX threshold and TX threshold. The interrupt is triggered when FIFO count is larger than or equal to RX threshold in RX path or FIFO count is less than or equal to TX threshold in TX path.</p> <p>Note, that the ITEN bit in the VDMAN_CON register shall be set or no interrupt will be issued. n is from 1 to 16.</p> |

| Aoo20714 VDMA7 CON |    | DMA channel 7 control |    |    |    |    |    |      |       |    |    |    |           | 00000000 |    |    |          |
|--------------------|----|-----------------------|----|----|----|----|----|------|-------|----|----|----|-----------|----------|----|----|----------|
| Bit Name           | 31 | 30                    | 29 | 28 | 27 | 26 | 25 | 24   | ITE N | 23 | 22 | 21 | 20        | 19       | 18 | 17 | 16 DR EQ |
| Type               |    |                       |    |    |    |    |    | RW   |       |    |    |    |           |          |    |    | RW       |
| Reset              |    |                       |    |    |    |    |    | 0    |       |    |    |    |           |          |    |    | 0        |
| Bit                | 15 | 14                    | 13 | 12 | 11 | 10 | 9  | 8    | 7     | 6  | 5  | 4  | 3         | 2        | 1  | 0  |          |
| Name               |    |                       |    |    |    |    |    | SIZE |       |    |    |    | DIRECTION |          |    |    |          |
| Type               |    |                       |    |    |    |    |    | RW   |       |    |    |    | RW        |          |    |    |          |
| Reset              |    |                       |    |    |    |    |    | 0    | 0     |    |    |    | DIR       |          |    |    |          |

| Bit(s) | Name      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24     | ITEN      | <b>Enable DMA transfer completion interrupt</b><br><ul style="list-style-type: none"> <li>0: Disable</li> <li>1: Enable</li> </ul>                                                                                                                                                                                                                                                                                                                                                                    |
| 16     | DREQ      | <b>Throttle and handshake control for DMA transfer.</b><br>The DMA master is able to throttle down the transfer rate by request-grant handshake. <ul style="list-style-type: none"> <li>0: No throttle control during DMA transfer or transfers occurred only between memories</li> <li>1: Hardware handshake management</li> </ul>                                                                                                                                                                   |
| 9:8    | SIZE      | <b>Data size within the confine of a bus cycle per transfer.</b><br>These bits confine the data transfer size between the source and destination to the specified value for individual bus cycle. The size is in terms of byte, and the maximum value is 4 bytes. It is mainly decided by the data width of a DMA master. <ul style="list-style-type: none"> <li>00: Byte transfer/1 byte</li> <li>01: Half-word transfer/2 bytes</li> <li>10: Word transfer/4 bytes</li> <li>11: Reserved</li> </ul> |
| 4:0    | DIRECTION | <b>[4]Directions of VDMA transfer</b><br>The direction is from the perspective of the DMA masters. WRITE means reading from master and then writing to the address specified in VDMA <sub>n</sub> _PGMADDR, and vice versa. No effect on channel 1.<br>[4]DIR: 0=peripheral TX; 1=peripheral RX                                                                                                                                                                                                       |

| <b>A0020718 VDMA7 START</b> |           | <b>DMA channel 7 start register</b> |           |           |           |           |           |           |           |           |           |           |           |           |           |           |  | <b>oooooooooooo</b> |  |  |  |  |  |  |  |  |
|-----------------------------|-----------|-------------------------------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|--|---------------------|--|--|--|--|--|--|--|--|
| <b>Bit Name</b>             | <b>31</b> | <b>30</b>                           | <b>29</b> | <b>28</b> | <b>27</b> | <b>26</b> | <b>25</b> | <b>24</b> | <b>23</b> | <b>22</b> | <b>21</b> | <b>20</b> | <b>19</b> | <b>18</b> | <b>17</b> | <b>16</b> |  |                     |  |  |  |  |  |  |  |  |
| <b>Type</b>                 |           |                                     |           |           |           |           |           |           |           |           |           |           |           |           |           |           |  |                     |  |  |  |  |  |  |  |  |
| <b>Rese t</b>               |           |                                     |           |           |           |           |           |           |           |           |           |           |           |           |           |           |  |                     |  |  |  |  |  |  |  |  |
| <b>Bit</b>                  | <b>15</b> | <b>14</b>                           | <b>13</b> | <b>12</b> | <b>11</b> | <b>10</b> | <b>9</b>  | <b>8</b>  | <b>7</b>  | <b>6</b>  | <b>5</b>  | <b>4</b>  | <b>3</b>  | <b>2</b>  | <b>1</b>  | <b>0</b>  |  |                     |  |  |  |  |  |  |  |  |
| <b>Name</b>                 | ST R      |                                     |           |           |           |           |           |           |           |           |           |           |           |           |           |           |  |                     |  |  |  |  |  |  |  |  |
| <b>Type</b>                 | RW        |                                     |           |           |           |           |           |           |           |           |           |           |           |           |           |           |  |                     |  |  |  |  |  |  |  |  |
| <b>Rese t</b>               | 0         |                                     |           |           |           |           |           |           |           |           |           |           |           |           |           |           |  |                     |  |  |  |  |  |  |  |  |

| Bit(s) | Name | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15     | STR  | <b>Start control for a DMA channel</b><br>This register controls the activity of a DMA channel. Note that prior to setting STR to 1, all the register settings should be configured. Once STR is set to 1, the hardware will not clear it automatically no matter the DMA channel accomplishes the DMA transfer or not. In other words, the value of STR stays at 1 regardless of the completion of the DMA transfer. Therefore, the software program should reset STR to 0 before restarting another DMA transfer. If this bit is cleared to 0 when DMA transfer is active, the software should poll RUNn in DMA_GLBSTA after this bit is cleared to ensure the current DMA transfer is terminated by the DMA engine. |

- 0: The DMA channel is stopped.
- 1: The DMA channel is started and running.

| <b>Aoo2071C VDMA7 INTSTA</b> |           | <b>DMA channel 7 interrupt status</b> |           |           |           |           |           |           |           |           |           |           |           |           |           |           | <b>oooooooooooo</b> |  |
|------------------------------|-----------|---------------------------------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|---------------------|--|
| <b>Bit</b>                   | <b>31</b> | <b>30</b>                             | <b>29</b> | <b>28</b> | <b>27</b> | <b>26</b> | <b>25</b> | <b>24</b> | <b>23</b> | <b>22</b> | <b>21</b> | <b>20</b> | <b>19</b> | <b>18</b> | <b>17</b> | <b>16</b> |                     |  |
| <b>Name</b>                  |           |                                       |           |           |           |           |           |           |           |           |           |           |           |           |           |           |                     |  |
| <b>Type</b>                  |           |                                       |           |           |           |           |           |           |           |           |           |           |           |           |           |           |                     |  |
| <b>Rese t</b>                |           |                                       |           |           |           |           |           |           |           |           |           |           |           |           |           |           |                     |  |
| <b>Bit</b>                   | <b>15</b> | <b>14</b>                             | <b>13</b> | <b>12</b> | <b>11</b> | <b>10</b> | <b>9</b>  | <b>8</b>  | <b>7</b>  | <b>6</b>  | <b>5</b>  | <b>4</b>  | <b>3</b>  | <b>2</b>  | <b>1</b>  | <b>0</b>  |                     |  |
| <b>Name</b>                  | INT       |                                       |           |           |           |           |           |           |           |           |           |           |           |           |           |           |                     |  |
| <b>Type</b>                  | RO        |                                       |           |           |           |           |           |           |           |           |           |           |           |           |           |           |                     |  |
| <b>Rese t</b>                | 0         |                                       |           |           |           |           |           |           |           |           |           |           |           |           |           |           |                     |  |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                                                                                                                               |
|---------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15            | INT         | <b>Interrupt status for DMA channel</b>                                                                                                                          |
|               |             | <ul style="list-style-type: none"> <li>• 0: No interrupt request is generated.</li> <li>• 1: An interrupt request is pending and waiting for service.</li> </ul> |

| <b>Aoo20720 VDMA7 ACKINT</b> |           | <b>DMA channel 7 interrupt acknowledge</b> |           |           |           |           |           |           |           |           |           |           |           |           |           |           | <b>oooooooooooo</b> |  |
|------------------------------|-----------|--------------------------------------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|---------------------|--|
| <b>Bit</b>                   | <b>31</b> | <b>30</b>                                  | <b>29</b> | <b>28</b> | <b>27</b> | <b>26</b> | <b>25</b> | <b>24</b> | <b>23</b> | <b>22</b> | <b>21</b> | <b>20</b> | <b>19</b> | <b>18</b> | <b>17</b> | <b>16</b> |                     |  |
| <b>Name</b>                  |           |                                            |           |           |           |           |           |           |           |           |           |           |           |           |           |           |                     |  |
| <b>Type</b>                  |           |                                            |           |           |           |           |           |           |           |           |           |           |           |           |           |           |                     |  |
| <b>Rese t</b>                |           |                                            |           |           |           |           |           |           |           |           |           |           |           |           |           |           |                     |  |
| <b>Bit</b>                   | <b>15</b> | <b>14</b>                                  | <b>13</b> | <b>12</b> | <b>11</b> | <b>10</b> | <b>9</b>  | <b>8</b>  | <b>7</b>  | <b>6</b>  | <b>5</b>  | <b>4</b>  | <b>3</b>  | <b>2</b>  | <b>1</b>  | <b>0</b>  |                     |  |
| <b>Name</b>                  | ACK       |                                            |           |           |           |           |           |           |           |           |           |           |           |           |           |           |                     |  |
| <b>Type</b>                  | WO        |                                            |           |           |           |           |           |           |           |           |           |           |           |           |           |           |                     |  |
| <b>Rese t</b>                | 0         |                                            |           |           |           |           |           |           |           |           |           |           |           |           |           |           |                     |  |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                                                                                                           |
|---------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 15            | ACK         | <b>Interrupt acknowledgement for the DMA channel</b>                                                                                         |
|               |             | <ul style="list-style-type: none"> <li>• 0: No effect</li> <li>• 1: Interrupt request is acknowledged and should be relinquished.</li> </ul> |

| <b>Aoo20728 VDMA7 LIMITER</b> |           | <b>DMA channel 7 bandwidth limiter</b> |           |           |           |           |           |           |           |           |           |           |           |           |           |           | <b>oooooooooooo</b> |  |
|-------------------------------|-----------|----------------------------------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|---------------------|--|
| <b>Bit</b>                    | <b>31</b> | <b>30</b>                              | <b>29</b> | <b>28</b> | <b>27</b> | <b>26</b> | <b>25</b> | <b>24</b> | <b>23</b> | <b>22</b> | <b>21</b> | <b>20</b> | <b>19</b> | <b>18</b> | <b>17</b> | <b>16</b> |                     |  |
| <b>Name</b>                   |           |                                        |           |           |           |           |           |           |           |           |           |           |           |           |           |           |                     |  |
| <b>Type</b>                   |           |                                        |           |           |           |           |           |           |           |           |           |           |           |           |           |           |                     |  |
| <b>Rese t</b>                 |           |                                        |           |           |           |           |           |           |           |           |           |           |           |           |           |           |                     |  |
| <b>Bit</b>                    | <b>15</b> | <b>14</b>                              | <b>13</b> | <b>12</b> | <b>11</b> | <b>10</b> | <b>9</b>  | <b>8</b>  | <b>7</b>  | <b>6</b>  | <b>5</b>  | <b>4</b>  | <b>3</b>  | <b>2</b>  | <b>1</b>  | <b>0</b>  |                     |  |
| <b>Name</b>                   |           |                                        |           |           |           |           |           |           |           |           |           |           |           |           |           |           | LIMITER             |  |
| <b>Type</b>                   |           |                                        |           |           |           |           |           |           |           |           |           |           |           |           |           |           | RW                  |  |

|      |   |  |  |  |  |  |  |  |  |   |   |   |   |   |   |   |   |   |
|------|---|--|--|--|--|--|--|--|--|---|---|---|---|---|---|---|---|---|
| Rese | t |  |  |  |  |  |  |  |  | o | o | o | o | o | o | o | o | o |
|------|---|--|--|--|--|--|--|--|--|---|---|---|---|---|---|---|---|---|

| Bit(s) | Name    | Description                                                                                                                                                                                                                                   |
|--------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0    | LIMITER | <b>Utilization Suppression</b><br>This register suppresses the bus utilization of the DMA channel. From 0 to 255. 0 means no limitation, 255 means totally banned, and others mean request for bus access permission every (4 x n) AHB clock. |

**A002072C VDMA7 PGMADDR DMA channel 7 programmable address 0oooooooo**

|          |         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----------|---------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit Name | 31      | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| PGMADDR  |         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type     | RW      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese     | t       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit      | 15      | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Nam      | PGMADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type     | RW      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese     | t       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name    | Description                                                                                                                                                                                                                        |
|--------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | PGMADDR | <b>VDMA programmable address.</b><br>Specifies the address for a half-size DMA channel. This address indicates that the source address if DIR in DMA_CON is set to 0 and the destination address of DIR in VDMAAn_CON is set to 1. |

**A0020730 VDMA7 WRPTR DMA channel 7 write pointer 0oooooooo**

|          |       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----------|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit Name | 31    | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| WRPTR    |       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type     | RO    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese     | t     | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit      | 15    | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Nam      | WRPTR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type     | RO    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese     | t     | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name  | Description                |
|--------|-------|----------------------------|
| 31:0   | WRPTR | Virtual FIFO write pointer |

**A0020734 VDMA7 RDPTR DMA channel 7 read pointer 0oooooooo**

|          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit Name | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| RDPTR    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type     | RO |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese     | t  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit   | 15    | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|-------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | RDPTR |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | RO    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0     | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| Bit(s) | Name  | Description               |
|--------|-------|---------------------------|
| 31:0   | RDPTR | Virtual FIFO read pointer |

| A0020738 VDMA7 FFCNT DMA channel 7 FIFO count 00000000 |       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|--------------------------------------------------------|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit                                                    | 31    | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name                                                   | FFCNT |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                                                   | RO    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset                                                  | 0     | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name  | Description                                                                                                  |
|--------|-------|--------------------------------------------------------------------------------------------------------------|
| 15:0   | FFCNT | Displays the number of data stored in FIFO.                                                                  |
|        |       | <ul style="list-style-type: none"> <li>0: FIFO is empty,</li> <li>• FFCNT = FFSize: FIFO is full.</li> </ul> |

| A002073C VDMA7 FFSTA DMA channel 7 FIFO status 00000000 |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|---------------------------------------------------------|--------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit                                                     | 31                 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name                                                    | AL T EM PT Y FU LL |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                                                    | RO RO RO           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset                                                   | 0                  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name  | Description                                                                                                                                                                                         |
|--------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2      | ALT   | <b>Indicates FIFO count is larger than ALTLEN.</b><br>DMA issues an alert signal to UART/BRIF to enable UART/BRIF flow control.<br>0: Did not reach the alert region<br>1: Reached the alert region |
| 1      | EMPTY | <b>Indicates FIFO is empty</b><br>0: Not empty<br>1: Empty                                                                                                                                          |

---

|   |      |                        |
|---|------|------------------------|
| 0 | FULL | Indicates FIFO is full |
|   |      | 0: Not full            |
|   |      | 1: Full                |

---

| <b>Aoo20740 VDMA7 ALTLEN</b> |    |    |    |    |    |    |    |    |    |    |               |    |    |    | <b>DMA channel 7 alert length</b> |    |   |   |
|------------------------------|----|----|----|----|----|----|----|----|----|----|---------------|----|----|----|-----------------------------------|----|---|---|
| <b>Bit Name</b>              | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21            | 20 | 19 | 18 | 17                                | 16 |   |   |
| <b>Type</b>                  |    |    |    |    |    |    |    |    |    |    |               |    |    |    |                                   |    |   |   |
| <b>Rese t</b>                |    |    |    |    |    |    |    |    |    |    |               |    |    |    |                                   |    |   |   |
| <b>Bit</b>                   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5             | 4  | 3  | 2  | 1                                 | 0  |   |   |
| <b>Name</b>                  |    |    |    |    |    |    |    |    |    |    | <b>ALTLEN</b> |    |    |    |                                   |    |   |   |
| <b>Type</b>                  |    |    |    |    |    |    |    |    |    |    | <b>RW</b>     |    |    |    |                                   |    |   |   |
| <b>Rese t</b>                |    |    |    |    |    |    |    |    |    |    | 0             | 0  | 0  | 0  | 0                                 | 0  | 0 | 0 |

---

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                                                                                                                                                                                                                       |
|---------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:0           | ALTLEN      | <b>Specifies the alert length of virtual FIFO DMA.</b><br>Once the remaining FIFO space is less than ALTLEN, an alert signal will be issued to UART/BRIF to enable the flow control. Normally, ALTLEN shall be bigger than 16 for UART/BRIF application. |

---

| <b>Aoo20744 VDMA7 FFSIZE</b> |    |    |    |    |    |    |    |    |    |               |    |    |    |    | <b>DMA channel 7 FIFO size</b> |    |   |   |
|------------------------------|----|----|----|----|----|----|----|----|----|---------------|----|----|----|----|--------------------------------|----|---|---|
| <b>Bit Name</b>              | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22            | 21 | 20 | 19 | 18 | 17                             | 16 |   |   |
| <b>Type</b>                  |    |    |    |    |    |    |    |    |    |               |    |    |    |    |                                |    |   |   |
| <b>Rese t</b>                |    |    |    |    |    |    |    |    |    |               |    |    |    |    |                                |    |   |   |
| <b>Bit</b>                   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6             | 5  | 4  | 3  | 2  | 1                              | 0  |   |   |
| <b>Name</b>                  |    |    |    |    |    |    |    |    |    | <b>FFSIZE</b> |    |    |    |    |                                |    |   |   |
| <b>Type</b>                  |    |    |    |    |    |    |    |    |    | <b>RW</b>     |    |    |    |    |                                |    |   |   |
| <b>Rese t</b>                | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0  | 0                              | 0  | 0 | 0 |

---

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                          |
|---------------|-------------|---------------------------------------------|
| 15:0          | FFSIZE      | Specifies the FIFO size of virtual FIFO DMA |

---

## 5. Universal Asynchronous Receiver/Transmitter

### 5.1. Overview

The universal asynchronous receiver transmitter (UART) provides full duplex serial communication channels between the baseband chipset and external devices.

The UART has both M16C450 and M16550A modes of operation, which are compatible with a range of standard software drivers. The extensions are designed to be broadly software compatible with M16550A variants, but certain areas offer no consensus.

The UART supports word lengths from 5 to 8 bits, an optional parity bit and one or two stop bits and is fully programmable by an 8-bit CPU interface. A 16-bit programmable baud rate generator and an 8-bit scratch register are included, together with separate transmit and receive FIFOs. Two modem control lines and a diagnostic loop-back mode are provided. The UART also includes two DMA handshake lines, indicating when the FIFOs are ready to transfer data to the CPU.

Note that the UART is designed so that all internal operation is synchronized by the clock signal. This synchronization results in minor timing differences between the UART and industry standard M16550A device, which means that the core is not clocked for clock identical to the original device.

After hardware reset, the UART will be in M16C450 mode. Its FIFOs can then be enabled and the UART can enter M16550A mode. The UART also has further additional functions beyond the M16550A mode. Each of the extended functions can be selected individually under software control.

### 5.2. Features

- There are three UART channels supporting hardware and software flow control. Each UART has an individual interrupt source.
- For transmission, the UART supports word lengths from 5 to 8 bits with an optional parity bit and one or two stop bits, and baud rate from 110bps to 921,600bps.
- There are dedicated DMA channels for both TX and RX for each UART.
- The UART supports auto baud rate detection in RX mode. The recommended baud rate range is from 300bps to 115,200bps.

### 5.3. Block diagram

Figure 5.3-1 shows the detailed UART block diagram.



**Figure 5.3-1. UART block diagram**

## 5.4. Functions

### 5.4.1. Baud rate generation

The UART contains a programmable baud generator. The baud rate generator divides the input clock by a divisor to generate a baud clock for data sampling. The baud clock is n times the baud rate where n is a positive integer. The formula to calculate the baud rate is:

$$\text{Baud Rate} = (\text{Input Clock Frequency}) / \text{Divisor} / n$$

The input clock frequency can be either **F\_FXO\_CK** or **F\_FXO\_CK/2**, the frequency of **F\_FXO\_CK** is 26MHz or 20MHz depending on the type of XO crystal. The divisor is stored in two 8-bit register fields (**DLH** and **DLL**) in register **DL**. The positive integer n is controlled by **HIGHSPEED.SPEED**.

- When **HIGHSPEED.SPEED** = 0, n = 16 and the data is sampled in the eighth baud clock cycle. When **HIGHSPEED.SPEED** = 1, n = 8 and the data is sampled in the fourth baud clock cycle.
- When **HIGHSPEED.SPEED** = 2, n = 4 and the data is sampled in the second baud clock cycle.
- When **HIGHSPEED.SPEED** = 3, n = **SAMPLE\_REG.SAMPLE\_COUNT+1** and the data is sampled in the (**SAMPLE\_REG.SAMPLE\_POINT**)<sup>th</sup> baud clock cycle.

### 5.4.2. Data format

The data format of the UART is shown in Figure 5.4-1. One transmission includes 1 start bit; 5, 6, 7 or 8 data bits; 1 optional parity bit; and 1 or 2 stop bits. The start bit is always low, the parity bit can be either odd or even parity, and the end bit is always high.



**Figure 5.4-1. UART data format**

### 5.4.3. Transmission

Transmission of the UART includes a TX holding register (THR) and TX shift register (TSR). THR receives data from Advanced Peripheral Bus (APB) and shifts to TSR. The data in TSR will then be serialized and sent to General-Purpose Input/Output (GPIO). In FIFO mode, the THR becomes a 16-byte FIFO.

### 5.4.4. Reception

Reception of the UART includes an RX buffer register (RBR) and RX shift register (RSR). RSR receives and concatenates the serial data bits from GPIO. The data will then be moved from RSR to RBR and ready to be read by APB. In FIFO mode, the RBR becomes a 32-byte FIFO.

### 5.4.5. Direct Memory Access (DMA) mode

The UART supports DMA mode operation only when the FIFOs are enabled (FCR.FIFOE == 1). Set DMA\_CON.TX\_DMA\_EN and DMA\_CON.RX\_DMA\_EN to 1 to enable DMA mode of transmission and reception, respectively.

### 5.4.6. Hardware flow control

The UART supports RTS/CTS hardware flow control. In transmission mode, the UART will pause transmission if CTS is asserted, and will resume transmission after CTS is de-asserted. In reception mode, the UART will assert RTS if one of the following conditions is met:

- 1) RBR is occupied in non-FIFO mode.
- 2) The amount of data in RBR is above threshold in FIFO mode or DMA mode.
- 3) The amount of data in virtual FIFO DMA is above threshold in DMA mode.
- 4) The system is entering sleep mode.

The UART will de-assert RTS when all of the above conditions are no longer met.

### 5.4.7. Software flow control

The UART supports XON/XOFF flow control. In transmission mode, the UART will pause transmission if an XOFF character is received and will resume transmission after receiving an XON character. In reception mode, the UART will send an XOFF character if one of the following conditions is met:

- 1) RBR is occupied in non-FIFO mode.
- 2) The amount of data in RBR is above threshold in FIFO mode or DMA mode.
- 3) The amount of data in virtual FIFO DMA is above threshold in DMA mode.
- 4) The system is entering sleep mode.

The UART will send an XON character when conditions 1, 2, and 3 are no longer valid. However, if the UART sends an XOFF character due to condition 4, the user should send an XON character manually after wake-up since the UART is powered down and all settings are cleared in sleep mode.

## 5.5. Register mapping

There are three UART interfaces supported in this chipset. The registers below are the same for all UARTs. The only difference is the base address.

| UART number | Base address | Feature                             |
|-------------|--------------|-------------------------------------|
| UART0       | 0xA00C0000   | Supports DMA, hardware flow control |
| UART1       | 0xA00D0000   | Supports DMA, hardware flow control |
| UART2       | 0xA00E0000   | Supports DMA, hardware flow control |

**Module name: UARTo Base address: (+aoocoooooh)**

| Address  | Name                | Width (bits) | Register Function                                 |
|----------|---------------------|--------------|---------------------------------------------------|
| A00C0000 | <b>RBR</b>          | 32           | <b>RX buffer register</b>                         |
| A00C0004 | <b>THR</b>          | 32           | <b>TX holding register</b>                        |
| A00C0008 | <b>DL</b>           | 32           | <b>Divisor latch</b>                              |
| A00C000C | <b>IER</b>          | 32           | <b>Interrupt enable register</b>                  |
| A00C0010 | <b>IIR</b>          | 32           | <b>Interrupt identification register</b>          |
| A00C0014 | <b>FCR</b>          | 32           | <b>FIFO control register</b>                      |
| A00C0018 | <b>EFR</b>          | 32           | <b>Enhanced feature register</b>                  |
| A00C001C | <b>LCR</b>          | 32           | <b>Line control register</b>                      |
| A00C0020 | <b>MCR</b>          | 32           | <b>Modem control register</b>                     |
| A00C0024 | <b>XON_XOFF</b>     | 32           | <b>XON &amp; XOFF character</b>                   |
| A00C0028 | <b>LSR</b>          | 32           | <b>Line status register</b>                       |
| A00C002C | <b>SCR</b>          | 32           | <b>Scratch register</b>                           |
| A00C0030 | <b>AUTOBAUD CON</b> | 32           | <b>Auto-baud control register</b>                 |
| A00C0034 | <b>HIGHSPEED</b>    | 32           | <b>High speed mode register</b>                   |
| A00C0038 | <b>SAMPLE REG</b>   | 32           | <b>Sample counter &amp; sample point register</b> |
| A00C003C | <b>AUTOBAUD REG</b> | 32           | <b>Auto-baud monitor register</b>                 |
| A00C0040 | <b>RATEFIX</b>      | 32           | <b>Clock rate fix register</b>                    |
| A00C0044 | <b>GUARD</b>        | 32           | <b>Guard interval register</b>                    |
| A00C0048 | <b>ESCAPE REG</b>   | 32           | <b>Escape character register</b>                  |
| A00C004C | <b>SLEEP REG</b>    | 32           | <b>Sleep mode control register</b>                |
| A00C0050 | <b>DMA CON</b>      | 32           | <b>DMA mode control register</b>                  |
| A00C0054 | <b>RXTRIG</b>       | 32           | <b>RX FIFO trigger threshold</b>                  |
| A00C0058 | <b>FRACDIV</b>      | 32           | <b>Fractional divisor</b>                         |
| A00C005C | <b>RX TO CON</b>    | 32           | <b>RX timeout mode control</b>                    |
| A00C0060 | <b>RX TOC DEST</b>  | 32           | <b>RX timeout counter destination value</b>       |

**AooCoooo RBR****RX buffer register****oooooooo**

| <b>Bit</b>   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16         |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0          |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>RBR</b> |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>RU</b>  |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    | 0  | 0  | 0  | 0          |

**Bit(s) Name****Description**

7:0      RBR

**RX buffer register****AooCooo4 THR****TX holding register****oooooooo**

| <b>Bit</b>   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16         |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0          |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>THR</b> |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>WO</b>  |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    | 0  | 0  | 0  | 0          |

**Bit(s) Name****Description**

7:0      THR

**TX holding register****AooCooo8 DL****Divisor latch****oooooooo01**

| <b>Bit</b>   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16         |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0          |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>DLM</b> |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>DLL</b> |
| <b>Reset</b> | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1          |

**Bit(s) Name****Description**

15:8    DLM

Divisor latch [15:8]

7:0      DLL

Divisor latch [7:0]

**AooCoooC IER****Interrupt enable register****oooooooo**

| <b>Bit</b>   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                 |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------|
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0                  |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                  |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>ELSI_ERB FI</b> |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>ETB EI</b>      |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW                 |

|       |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|-------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|-------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|

| Bit(s) | Name       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 25:24  | CTSI_RTSI  | <p><b>CTS &amp; RTS interrupt</b></p> <p>Note: This interrupt is only enabled when hardware flow control is enabled.</p> <ul style="list-style-type: none"> <li>• Bit[1] - When a rising edge is detected on the CTS modem control line:           <ul style="list-style-type: none"> <li>○ 0: No effect</li> <li>○ 1: Interrupt is generated</li> </ul> </li> <li>• Bit[0] - When a rising edge is detected on the RTS modem control line:           <ul style="list-style-type: none"> <li>○ 0: No effect</li> <li>○ 1: Interrupt is generated</li> </ul> </li> </ul> |
| 16     | XOFFI      | <p><b>XOFF interrupt</b></p> <p>Note: This interrupt is only enabled when software flow control is enabled.</p> <ul style="list-style-type: none"> <li>• When an XOFF character is received:           <ul style="list-style-type: none"> <li>○ 0: No effect</li> <li>○ 1: Interrupt is generated</li> </ul> </li> </ul>                                                                                                                                                                                                                                                |
| 9:8    | ELSI_ERBFI | <p><b>RX interrupt</b></p> <p>Bit[1] - When BI, FE, PE, or OE becomes set:</p> <ul style="list-style-type: none"> <li>○ 0: No effect</li> <li>○ 1: Interrupt is generated</li> </ul> <p>Bit[0] - When RX buffer register is full or RX FIFO threshold is reached:</p> <ul style="list-style-type: none"> <li>○ 0: No effect</li> <li>○ 1: Interrupt is generated</li> </ul>                                                                                                                                                                                             |
| 0      | ETBEI      | <p><b>TX interrupt</b></p> <ul style="list-style-type: none"> <li>• When TX holding register is empty or TX FIFO threshold is reached:           <ul style="list-style-type: none"> <li>○ 0: No effect</li> <li>○ 1: Interrupt is generated</li> </ul> </li> </ul>                                                                                                                                                                                                                                                                                                      |

| AooCoo10 IIR |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Interrupt identification register |    |   |   |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------------|----|---|---|
| Bit          | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17                                | 16 |   |   |
| Name         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                   |    |   |   |
| Type         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                   |    |   |   |
| Reset        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                   |    |   |   |
| Bit          | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1                                 | 0  |   |   |
| Name         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                   | ID |   |   |
| Type         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                   | RU |   |   |
| Reset        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                   | 0  | 0 | 0 |

| Bit(s) | Name | Description                                                                                                                                                                                                                              |        |   |                      |        |   |                                                     |
|--------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|---|----------------------|--------|---|-----------------------------------------------------|
| 5:0    | ID   | <p><b>IIR[5:0] Priority Interrupt source</b></p> <table> <tr> <td>000001</td> <td>-</td> <td>No pending interrupt</td> </tr> <tr> <td>000110</td> <td>1</td> <td>Line Status Interrupt: BI, FE, PE, or OE set in LSR</td> </tr> </table> | 000001 | - | No pending interrupt | 000110 | 1 | Line Status Interrupt: BI, FE, PE, or OE set in LSR |
| 000001 | -    | No pending interrupt                                                                                                                                                                                                                     |        |   |                      |        |   |                                                     |
| 000110 | 1    | Line Status Interrupt: BI, FE, PE, or OE set in LSR                                                                                                                                                                                      |        |   |                      |        |   |                                                     |

---

|        |   |                                                          |
|--------|---|----------------------------------------------------------|
| 001100 | 2 | RX data timeout                                          |
| 000100 | 3 | RX data received or RX trigger level reached             |
| 000010 | 4 | TX holding register is empty or TX trigger level reached |
| 010000 | 5 | Software flow control: received XOFF                     |
| 100000 | 6 | Hardware flow control: CTS or RTS rising edge            |

Line status interrupt:

RX line status interrupt is generated, if IER [9] and any of BI, FE, PE or OE (LSR [4:1]) are set. The interrupt is cleared by reading the LSR register.

RX data timeout interrupt:

(RX\_TO\_MODE = 0)

When RX DMA mode is disabled, RX data timeout interrupt is generated, if the following conditions apply:

- FIFO is not empty.
- No data is received for four transmission periods
- FIFO is not read by the CPU for four transmission periods.

The timeout timer restarts upon receipt of a new byte from the RX shift register or upon a CPU read from the RX FIFO. The RX data timeout interrupt is enabled by setting IER[8] to 1 and RX\_TO\_MODE to 0, and is cleared by reading RX FIFO.

When RX DMA mode is enabled, RX data timeout interrupt is generated, if the following conditions apply:

- FIFO is empty.
- The most recent character is received longer than four character periods ago (including all start, parity and stop bits).

The timeout timer restarts upon receipt of a new byte from the RX shift register or reading the DMA\_CON register. The RX data timeout interrupt is enabled by setting IER[8] to 1 and RX\_TO\_MODE to 0, and is cleared by reading the DMA\_CON register.

(RX\_TO\_MODE = 1)

When RX DMA mode is disabled, RX data timeout interrupt is generated, if the following conditions apply:

- FIFO is not empty.
- No data is received for a certain period (defined by RX\_TOC\_DEST).
- FIFO is not read by the CPU for a certain period (defined by RX\_TOC\_DEST).

The timeout timer restarts upon receipt of a new byte from the RX shift register or upon a CPU read from the RX FIFO. The RX data timeout interrupt is enabled by setting IER[8] to 1 and RX\_TO\_MODE to 1, and is cleared by reading RX FIFO.

When RX DMA mode is enabled, RX data timeout interrupt is generated, if the following conditions apply:

- FIFO is empty.
- The most recent character is received longer than a certain period ago (defined by RX\_TOC\_DEST).

The timeout timer restarts upon receipt of a new byte from the RX shift register or reading the DMA\_CON register. The RX data timeout interrupt is enabled by setting IER[8] to 1 and RX\_TO\_MODE to 1, and is cleared by reading the DMA\_CON register.

**RX data received an interrupt:**

RX data received an interrupt is generated if IER[8] is set and either RX data are placed in the RX buffer register or the RX trigger level is reached. The interrupt is cleared by reading the RX buffer register or the RX FIFO (if enabled).

**TX holding register empty interrupt:**

A TX holding register empty interrupt is generated, if IER[0] is set and either the TX holding register is empty or the contents of the TX FIFO are reduced to its trigger level. The interrupt is cleared by writing to the TX holding register or TX FIFO (if enabled).

**Software flow control interrupt:**

A software flow control interrupt is generated, if the software flow control is enabled and XOFFI (IER[16]) is set, indicating that an XOFF character has been received. The interrupt is cleared by reading the IIR register.

**Hardware flow control interrupt:**

A hardware flow control interrupt is generated, if the hardware flow control is enabled and either IER[24] or IER[25] is set indicating that a rising edge has been detected on RTS or CTS modem control line. The interrupt is cleared by reading the IIR register.

| <b>AooCoo14 FCR</b> |    |    |    |    |    |    |    |             |           |          |          |          |          |    |    | <b>FIFO control register</b> |                  |  |  |  |  |  |  | <b>oooooooo</b> |  |  |  |  |  |  |  |  |
|---------------------|----|----|----|----|----|----|----|-------------|-----------|----------|----------|----------|----------|----|----|------------------------------|------------------|--|--|--|--|--|--|-----------------|--|--|--|--|--|--|--|--|
| <b>Bit</b>          | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24          | 23        | 22       | 21       | 20       | 19       | 18 | 17 | 16                           |                  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |
| <b>Name</b>         |    |    |    |    |    |    |    | <b>CLRT</b> |           |          |          |          |          |    |    |                              |                  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |
| <b>Type</b>         |    |    |    |    |    |    |    |             | <b>WO</b> |          |          |          |          |    |    |                              |                  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |
| <b>Reset</b>        |    |    |    |    |    |    |    |             |           | <b>0</b> |          |          |          |    |    |                              |                  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |
| <b>Bit</b>          | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8           | 7         | 6        | 5        | 4        | 3        | 2  | 1  | 0                            |                  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |
| <b>Name</b>         |    |    |    |    |    |    |    |             |           |          |          |          |          |    |    |                              | <b>RFTL_TFTL</b> |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |
| <b>Type</b>         |    |    |    |    |    |    |    |             |           |          |          |          |          |    |    |                              | <b>RW</b>        |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |
| <b>Reset</b>        |    |    |    |    |    |    |    |             |           | <b>0</b> | <b>0</b> | <b>0</b> | <b>0</b> |    |    |                              |                  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                                                                                                                                                                                                                   |
|---------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24            | CLRT        | <b>Clear TX FIFO</b> <ul style="list-style-type: none"> <li>• 0: No effect</li> <li>• 1: Clear</li> </ul>                                                                                                                                            |
| 16            | CLRR        | <b>Clear RX FIFO</b> <ul style="list-style-type: none"> <li>• 0: No effect</li> <li>• 1: Clear</li> </ul>                                                                                                                                            |
| 11:8          | RFTL_TFTL   | <b>RX &amp; TX FIFO trigger threshold</b> <ul style="list-style-type: none"> <li>• Bit[3:2] - RX FIFO threshold (total 32 bytes):           <ul style="list-style-type: none"> <li>○ 00: 1</li> <li>○ 01: 6</li> <li>○ 10: 12</li> </ul> </li> </ul> |

- 11: Use RXTRIG register value
  - Bit[1:0] - TX FIFO threshold (total 16 bytes):
    - 00: 1
    - 01: 4
    - 10: 8
    - 11: 14
- 0 FIFOE
- Enable RX & TX FIFOs**
- 0: Disable
  - 1: Enable

**AooCoo18 EFR****Enhanced feature register****oooooooo**

| Bit          | 31 | 30 | 29 | 28 | 27 | 26 | 25                  | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17                  | 16               |
|--------------|----|----|----|----|----|----|---------------------|----|----|----|----|----|----|----|---------------------|------------------|
| <b>Name</b>  |    |    |    |    |    |    | <b>SEND_XON</b>     |    |    |    |    |    |    |    |                     | <b>SEND_XOFF</b> |
| <b>Type</b>  |    |    |    |    |    |    |                     | WO |    |    |    |    |    |    |                     | WO               |
| <b>Reset</b> |    |    |    |    |    |    |                     | 0  |    |    |    |    |    |    |                     | 0                |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9                   | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1                   | 0                |
| <b>Name</b>  |    |    |    |    |    |    | <b>HW_FLOW_CONT</b> |    |    |    |    |    |    |    | <b>SW_FLOW_CONT</b> |                  |
| <b>Type</b>  |    |    |    |    |    |    |                     | RW |    |    |    |    |    |    |                     | RW               |
| <b>Reset</b> |    |    |    |    |    |    |                     | 0  | 0  |    |    |    |    |    | 0                   | 0                |

**Bit(s) Name****Description**

24 SEND\_XON

**Send XON**

Note: effective only when TX software flow control is disabled

0: No effect

1: Auto send one XON character

16 SEND\_XOFF

**Send XOFF**

Note: effective only when TX software flow control is disabled

0: No effect

1: Auto send one XOFF character

9:8 HW\_FLOW\_CONT

**Hardware flow control**

Bit[1] - TX hardware flow control:

0: Disable TX flow control

1: Enable TX to receive CTS

Bit[0] - RX hardware flow control:

0: Disable RX flow control

1: Enable RX to send RTS

1:0 SW\_FLOW\_CONT

**Software flow control**

Bit[1] - TX software flow control:

0: Disable TX flow control

1: Transmit XON/XOFF as flow control byte

Bit[0] - RX software flow control:

0: Disable RX flow control

1: Receive XON/XOFF as flow control byte

**AooCoo1C LCR****Line control register****00000020**

| <b>Bit</b>   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24        | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|----|----|----|----|----|----|----|-----------|----|----|----|----|----|----|----|----|
| <b>Name</b>  |    |    |    |    |    |    |    |           |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |           |    |    |    |    |    |    |    |    |
| <b>Reset</b> |    |    |    |    |    |    |    |           |    |    |    |    |    |    |    |    |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8         | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  |    |    |    |    |    |    |    | <b>SB</b> |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    | <b>RW</b> |    |    |    |    |    |    |    |    |
| <b>Reset</b> |    |    |    |    |    |    |    | 0         |    |    | 1  | 0  | 0  | 0  | 0  | 0  |

**Bit(s) Name****Description**

8 SB

**Set break**

0: No effect

1: TX signal is forced to 0

5:0 PAR\_STB\_WLS

**Parity, stop bits, & word length setting**

Bit[5:3] - Parity type:

000: Even parity

001: Odd parity

010: Parity is forced to 0

011: Parity is forced to 1

100: No parity

Bit[2] - Number of stop bits:

0: 1 stop bit

1: 2 stop bits (effective only when word length &gt; 5 bits)

Bit[1:0] - Word length:

00: 5 bits

01: 6 bits

10: 7 bits

11: 8 bits

**AooCoo20 MCR****Modem control register****00000000**

| <b>Bit</b>   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24          | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16           |
|--------------|----|----|----|----|----|----|----|-------------|----|----|----|----|----|----|----|--------------|
| <b>Name</b>  |    |    |    |    |    |    |    |             |    |    |    |    |    |    |    | XOFF_STA_TUS |
| <b>Type</b>  |    |    |    |    |    |    |    |             |    |    |    |    |    |    |    | RU           |
| <b>Reset</b> |    |    |    |    |    |    |    |             |    |    |    |    |    |    |    | 0            |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8           | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0            |
| <b>Name</b>  |    |    |    |    |    |    |    | <b>LOOP</b> |    |    |    |    |    |    |    | RTS          |
| <b>Type</b>  |    |    |    |    |    |    |    | <b>RW</b>   |    |    |    |    |    |    |    | RW           |
| <b>Reset</b> |    |    |    |    |    |    |    | 0           |    |    |    |    |    |    |    | 0            |

**Bit(s) Name****Description**

16 XOFF\_STATUS

**XOFF status**

0: No XOFF character is received

1: A XOFF character is received

8 LOOP

**Enable loop-back mode, i.e. connect TX to RX**

---

Note: HW flow control will be disabled in loop-back mode

0: Disable

1: Enable

0 RTS

**RTS state**

0: RTS is always 1

1: RTS value will be decided by hardware flow control

---

**AooCoo24 XON\_XOFF**

**XON & XOFF character**

**oooooooo**

| Bit   | 31              | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23               | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|-----------------|----|----|----|----|----|----|----|------------------|----|----|----|----|----|----|----|
| Name  |                 |    |    |    |    |    |    |    |                  |    |    |    |    |    |    |    |
| Type  |                 |    |    |    |    |    |    |    |                  |    |    |    |    |    |    |    |
| Reset |                 |    |    |    |    |    |    |    |                  |    |    |    |    |    |    |    |
| Bit   | 15              | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7                | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>XON_CHAR</b> |    |    |    |    |    |    |    | <b>XOFF_CHAR</b> |    |    |    |    |    |    |    |
| Type  | RW              |    |    |    |    |    |    |    | RW               |    |    |    |    |    |    |    |
| Reset | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**Bit(s) Name**

**Description**

15:8 XON\_CHAR XON character for software flow control

7:0 XOFF\_CHAR XOFF character for software flow control

---

**AooCoo28 LSR**

**Line status register**

**oooooooo60**

| Bit   | 31         | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23        | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|------------|----|----|----|----|----|----|----|-----------|----|----|----|----|----|----|----|
| Name  |            |    |    |    |    |    |    |    |           |    |    |    |    |    |    |    |
| Type  |            |    |    |    |    |    |    |    |           |    |    |    |    |    |    |    |
| Reset |            |    |    |    |    |    |    |    |           |    |    |    |    |    |    |    |
| Bit   | 15         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7         | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>LSR</b> |    |    |    |    |    |    |    | <b>RU</b> |    |    |    |    |    |    |    |
| Type  | RU         |    |    |    |    |    |    |    | 0         | 1  | 1  | 0  | 0  | 0  | 0  | 0  |
| Reset |            |    |    |    |    |    |    |    |           |    |    |    |    |    |    |    |

**Bit(s) Name**

**Description**

7:0 LSR Line status register

Bit[7] - RX FIFO error:

0: No PE, FE, and BI in the RX FIFO

1: At least one of PE, FE, or BI in the RX FIFO

Bit[6] - TX holding register/TX FIFO and TX shift register are empty:

0: Empty conditions below are not met.

1: Set whenever the TX FIFO and the TX shift register are empty (FIFOs are enabled), or TX holding register and TX shift register are empty (FIFOs are disabled).

Bit[5] - TX holding register is empty or TX FIFO is below threshold:

0: Reset whenever the contents of the TX FIFO are above threshold (FIFOs are enabled), or TX holding register is not empty (FIFOs are disabled).

1: Set whenever the contents of the TX FIFO are below threshold (FIFOs are enabled), or TX holding register is empty and ready to

---

accept new data (FIFOs are disabled).

Bit[4] - Break interrupt (BI):

o: Reset by CPU reading this register.

1: Set if the RX is held in o state for more than one transmission time (START bit + DATA bits + PARITY + STOP bits).

Bit[3] - Framing error (FE):

o: Reset by CPU reading this register.

1: Set if the received data does not have a valid STOP bit.

Bit[2] - Parity error (PE):

o: Reset by CPU reading this register.

1: Set if the received data do not have a valid parity bit.

Bit[1] - Overrun error (OE):

o: Reset by CPU reading this register.

1: Set if the RX buffer register is overwritten (FIFOs are disabled), or both RX FIFO and RX shift register is full (FIFOs are enabled). Note, that if OE occurs and UART is still receiving data in FIFO mode, the data in the FIFO will be keep but the RX shifter register will be overwritten.

Bit[0] - Data ready (DR):

o: Reset by CPU reading the RX buffer or by reading all the FIFO bytes.

1: Set if the RX buffer register or FIFO is not empty.

| <b>AooCoo2C SCR</b> |    | <b>Scratch register</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           | <b>oooooooo</b> |   |   |   |   |   |   |  |
|---------------------|----|-------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------|-----------------|---|---|---|---|---|---|--|
| <b>Bit</b>          | 31 | 30                      | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |           |                 |   |   |   |   |   |   |  |
| <b>Name</b>         |    |                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |                 |   |   |   |   |   |   |  |
| <b>Type</b>         |    |                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |                 |   |   |   |   |   |   |  |
| <b>Reset</b>        |    |                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |                 |   |   |   |   |   |   |  |
| <b>Bit</b>          | 15 | 14                      | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |           | <b>SCR</b>      |   |   |   |   |   |   |  |
| <b>Name</b>         |    |                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>RW</b> |                 |   |   |   |   |   |   |  |
| <b>Type</b>         |    |                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    | x         | x               | x | x | x | x | x | x |  |
| <b>Reset</b>        |    |                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |           |                 |   |   |   |   |   |   |  |

#### **Bit(s) Name**

#### **Description**

7:0      SCR

**General purpose read/write register**

Note: This register will not be reset

| <b>AooCoo30 AUTOBAUD CON</b> |    | <b>Autobaud control register</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                              | <b>oooooooo</b> |  |  |  |  |  |                     |  |
|------------------------------|----|----------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------------------------------------|-----------------|--|--|--|--|--|---------------------|--|
| <b>Bit</b>                   | 31 | 30                               | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |                                              |                 |  |  |  |  |  |                     |  |
| <b>Name</b>                  |    |                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>AUTO<br/>BAU<br/>D_SL<br/>EEP<br/>ACK</b> |                 |  |  |  |  |  |                     |  |
| <b>Type</b>                  |    |                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                              | <b>RW</b>       |  |  |  |  |  |                     |  |
| <b>Reset</b>                 |    |                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                              |                 |  |  |  |  |  | <b>o</b>            |  |
| <b>Bit</b>                   | 15 | 14                               | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  | <b>AUTO<br/>BAUD</b>                         |                 |  |  |  |  |  |                     |  |
| <b>Name</b>                  |    |                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                              |                 |  |  |  |  |  | <b>AUTO<br/>BAU</b> |  |

|       |  |  |  |  |  |  |            |  |  |  |  |  |  |  |             |
|-------|--|--|--|--|--|--|------------|--|--|--|--|--|--|--|-------------|
| Type  |  |  |  |  |  |  | <b>SEL</b> |  |  |  |  |  |  |  | <b>D_EN</b> |
| Reset |  |  |  |  |  |  | RW         |  |  |  |  |  |  |  | RW          |
|       |  |  |  |  |  |  | 0          |  |  |  |  |  |  |  | 0           |

| <b>Bit(s)</b> | <b>Name</b>        | <b>Description</b>                                                                                                        |
|---------------|--------------------|---------------------------------------------------------------------------------------------------------------------------|
| 16            | AUTOBAUD_SLEEP_ACK | <b>Enable auto-baud sleep acknowledgment</b><br>Note: effective only when auto-baud is enabled<br>0: Enable<br>1: Disable |
| 8             | AUTOBAUD_SEL       | <b>Auto-baud mode</b><br>0: Support standard baud rate<br>1: Support non-standard baud rate (from 300 to 115200 Hz)       |
| 0             | AUTOBAUD_EN        | <b>Enable auto-baud</b><br>0: Disable<br>1: Enable                                                                        |

| <b>AooCoo34 HIGHSPEED</b>       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |
|---------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------|
| <b>High speed mode register</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |
| <b>oooooooooooo</b>             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |
| <b>Bit</b>                      | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16           |
| <b>Name</b>                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |
| <b>Type</b>                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |
| <b>Reset</b>                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |
| <b>Bit</b>                      | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0            |
| <b>Name</b>                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>SPEED</b> |
| <b>Type</b>                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>RW</b>    |
| <b>Reset</b>                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0            |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                                                                                                                                                               |
|---------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0           | SPEED       | <b>Sample counter period</b><br>0: 16*(baud pulse)<br>1: 8*(baud pulse)<br>2: 4*(baud pulse)<br>3: (SAMPLE_REG.SAMPLE_COUNT+1)*(baud pulse)<br>Note: Baud rate = system clock frequency/speed/DL |

| <b>AooCoo38 SAMPLE_REG</b>                        |                     |    |    |    |    |    |    |    |                     |    |    |    |    |    |    |    |
|---------------------------------------------------|---------------------|----|----|----|----|----|----|----|---------------------|----|----|----|----|----|----|----|
| <b>Sample counter &amp; sample point register</b> |                     |    |    |    |    |    |    |    |                     |    |    |    |    |    |    |    |
| <b>ooooFFoo</b>                                   |                     |    |    |    |    |    |    |    |                     |    |    |    |    |    |    |    |
| <b>Bit</b>                                        | 31                  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23                  | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b>                                       |                     |    |    |    |    |    |    |    |                     |    |    |    |    |    |    |    |
| <b>Type</b>                                       |                     |    |    |    |    |    |    |    |                     |    |    |    |    |    |    |    |
| <b>Reset</b>                                      |                     |    |    |    |    |    |    |    |                     |    |    |    |    |    |    |    |
| <b>Bit</b>                                        | 15                  | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7                   | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>                                       | <b>SAMPLE_POINT</b> |    |    |    |    |    |    |    | <b>SAMPLE_COUNT</b> |    |    |    |    |    |    |    |
| <b>Type</b>                                       | <b>RW</b>           |    |    |    |    |    |    |    | <b>RW</b>           |    |    |    |    |    |    |    |
| <b>Reset</b>                                      | 1                   | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 0                   | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| <b>Bit(s)</b> | <b>Name</b>  | <b>Description</b>  |
|---------------|--------------|---------------------|
| 15:8          | SAMPLE_POINT | <b>Sample point</b> |

Note: Usually (SAMPLE\_COUNT-1)/2 without decimal. Effective only when SPEED = 3

7:0 SAMPLE\_COUNT

#### Sample counter

Note: Effective only when SPEED = 3

### AooCoo3C AUTOBAUD\_REG

### Autobaud monitor register

oooooooo

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    | 0  | 0  | 0  | 0  |    |    |    | 0  | 0  | 0  | 0  |

#### Bit(s) Name

#### Description

11:8 BAUD\_STAT

#### Auto-baud state

- 0: Detecting
- 1: AT\_7N1
- 2: AT\_7O1
- 3: AT\_7E1
- 4: AT\_8N1
- 5: AT\_8O1
- 6: AT\_8E1
- 7: at\_7N1
- 8: at\_7E1
- 9: at\_7O1
- 10: at\_8N1
- 11: at\_8E1
- 12: at\_8O1
- 13: Detection fail

3:0 BAUD\_RATE

#### Auto-baud rate

- 0: 115,200
- 1: 57,600
- 2: 38,400
- 3: 19,200
- 4: 9,600
- 5: 4,800
- 6: 2,400
- 7: 1,200
- 8: 300

### AooCoo40 RATEFIX

### Clock rate fix register

ooooooooD

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16       |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RATE FIX |

|       |    |    |    |    |    |    |   |                              |   |   |   |   |   |   |   |    |
|-------|----|----|----|----|----|----|---|------------------------------|---|---|---|---|---|---|---|----|
| Type  |    |    |    |    |    |    |   |                              |   |   |   |   |   |   |   | RW |
| Reset |    |    |    |    |    |    |   |                              |   |   |   |   |   |   |   | 0  |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8                            | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0  |
| Name  |    |    |    |    |    |    |   | AUTO<br>BAUD<br>_RAT<br>EFIX |   |   |   |   |   |   |   |    |
| Type  |    |    |    |    |    |    |   | RW                           |   |   |   |   |   |   |   | RW |
| Reset |    |    |    |    |    |    |   | 0                            |   |   | 0 | 0 | 1 | 1 | 0 | 1  |

| Bit(s) | Name             | Description                                                                                                                                                                                                                                            |
|--------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16     | RATEFIX          | <b>System clock rate for TX/RX</b><br>0: 26MHz / 20MHz<br>1: 13MHz / 10MHz                                                                                                                                                                             |
| 8      | AUTOBAUD_RATEFIX | <b>System clock rate for auto-baud detection</b><br>0: 26MHz / 20MHz<br>1: 13MHz / 10MHz                                                                                                                                                               |
| 5:0    | AUTOBAUD_SAMPLE  | <b>Clock division for auto-baud detection</b><br>{ RATE_FIX, AUTOBAUD_RATEFIX } = { 0, 0 }: 0xf<br>{ RATE_FIX, AUTOBAUD_RATEFIX } = { 0, 1 }: 0x7<br>{ RATE_FIX, AUTOBAUD_RATEFIX } = { 1, 0 }: 0x1f<br>{ RATE_FIX, AUTOBAUD_RATEFIX } = { 1, 1 }: 0x0 |

| AooCoo44 GUARD |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Guard interval register |  |  |  | 0000000F |  |  |  |
|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------------|--|--|--|----------|--|--|--|
| Bit            | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |                         |  |  |  |          |  |  |  |
| Name           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         |  |  |  |          |  |  |  |
| Type           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         |  |  |  |          |  |  |  |
| Reset          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         |  |  |  |          |  |  |  |
| Bit            | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |                         |  |  |  |          |  |  |  |
| Name           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         |  |  |  |          |  |  |  |
| Type           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                         |  |  |  |          |  |  |  |
| Reset          |    |    |    |    |    |    |    |    |    |    |    |    | 0  | 1  | 1  | 1  |                         |  |  |  |          |  |  |  |

| Bit(s) | Name  | Description                                                                                                                                                                |
|--------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4:0    | GUARD | <b>Guard interval setting</b><br>Bit[4] - Enable guard interval:<br>0: No guard interval<br>1: Add guard interval after stop bit<br>Bit[3:0] - Guard interval count value: |

| AooCoo48 ESCAPE_REG |    |    |    |    |    |    |    |        |    |    |    |    |    |    |    |    | Escape character register |  |  |  | 000000FF |  |  |  |
|---------------------|----|----|----|----|----|----|----|--------|----|----|----|----|----|----|----|----|---------------------------|--|--|--|----------|--|--|--|
| Bit                 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24     | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |                           |  |  |  |          |  |  |  |
| Name                |    |    |    |    |    |    |    |        |    |    |    |    |    |    |    |    |                           |  |  |  |          |  |  |  |
| Type                |    |    |    |    |    |    |    |        |    |    |    |    |    |    |    |    |                           |  |  |  |          |  |  |  |
| Reset               |    |    |    |    |    |    |    |        |    |    |    |    |    |    |    |    |                           |  |  |  |          |  |  |  |
| Bit                 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8      | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |                           |  |  |  |          |  |  |  |
| Name                |    |    |    |    |    |    |    | ESC_EN |    |    |    |    |    |    |    |    |                           |  |  |  |          |  |  |  |
| Type                |    |    |    |    |    |    |    |        |    |    |    |    |    |    |    |    |                           |  |  |  |          |  |  |  |
| Reset               |    |    |    |    |    |    |    |        |    |    |    |    |    |    |    |    |                           |  |  |  |          |  |  |  |

| Type  |  |  |  |  |  |  | RW |   |   |   |   |   |   |   |   |
|-------|--|--|--|--|--|--|----|---|---|---|---|---|---|---|---|
| Reset |  |  |  |  |  |  | 0  | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |

| Bit(s) | Name     | Description                                               |
|--------|----------|-----------------------------------------------------------|
| 8      | ESC_EN   | <b>Enable escape character</b><br>0: Disable<br>1: Enable |
| 7:0    | ESC_CHAR | <b>Escape character setting</b>                           |

| AooCoo4C SLEEP_REG Sleep mode control register 0oooooooooooo |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |
|--------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|
| Bit                                                          | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16       |
| Name                                                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |
| Type                                                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |
| Reset                                                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |
| Bit                                                          | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0        |
| Name                                                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | SLEEP_EN |
| Type                                                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW       |
| Reset                                                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0        |

| Bit(s) | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                     |
|--------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | SLEEP_EN | <b>For sleep mode issue</b><br>0: No active flow control when the chip enters sleep mode.<br>1: Active hardware flow control (assert RTS) or software flow control (send XOFF) when the chip enters sleep mode. Release hardware flow control (de-assert RTS) when the chip wakes up. However, for software control, XON should be sent manually when awakened (can use the SEND_XON register). |

| AooCoo50 DMA_CON DMA mode control register 0oooooooooooo |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |
|----------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------|
| Bit                                                      | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16           |
| Name                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | FIFO_LSR_SEL |
| Type                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW           |
| Reset                                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0            |
| Bit                                                      | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0            |
| Name                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RX_DMA_EN    |
| Type                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW           |
| Reset                                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0            |

| Bit(s) | Name         | Description                                                                                                                            |
|--------|--------------|----------------------------------------------------------------------------------------------------------------------------------------|
| 16     | FIFO_LSR_SEL | <b>FIFO LSR mode</b><br>0: LSR holds the first line status error state until the LSR register is read.<br>1: LSR updates automatically |
| 8      | TX_DMA_EN    | <b>Enable TX DMA mode</b>                                                                                                              |

---

|   |           |                           |
|---|-----------|---------------------------|
|   |           | 0: Disable<br>1: Enable   |
| 0 | RX_DMA_EN | <b>Enable RX DMA mode</b> |
|   |           | 0: Disable<br>1: Enable   |

---

| <b>AooCoo54 RXTRIG</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>RX FIFO trigger threshold</b> |               |  |  |
|------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------------------------|---------------|--|--|
| <b>Bit</b>             | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                               |               |  |  |
| <b>Name</b>            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                  |               |  |  |
| <b>Type</b>            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                  |               |  |  |
| <b>Reset</b>           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                  |               |  |  |
| <b>Bit</b>             | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                                |               |  |  |
| <b>Name</b>            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                  | <b>RXTRIG</b> |  |  |
| <b>Type</b>            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                  | <b>RW</b>     |  |  |
| <b>Reset</b>           |    |    |    |    |    |    |    |    |    |    |    |    | 0  | 0  | 0  | 0                                | 0             |  |  |

---

| <b>Bit(s)</b>                      | <b>Name</b> | <b>Description</b>               |
|------------------------------------|-------------|----------------------------------|
| 3:0                                | RXTRIG      | <b>RX FIFO trigger threshold</b> |
| Note: effective only when RFTL = 3 |             |                                  |

---

| <b>AooCoo58 FRACDIV</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>Fractional divisor</b> |                |  |  |
|-------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------------|----------------|--|--|
| <b>Bit</b>              | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                        |                |  |  |
| <b>Name</b>             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           |                |  |  |
| <b>Type</b>             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           |                |  |  |
| <b>Reset</b>            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           |                |  |  |
| <b>Bit</b>              | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                         |                |  |  |
| <b>Name</b>             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           | <b>FRACDIV</b> |  |  |
| <b>Type</b>             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           | <b>RW</b>      |  |  |
| <b>Reset</b>            |    |    |    |    |    |    |    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                         | 0              |  |  |

---

| <b>Bit(s)</b>                                                                           | <b>Name</b> | <b>Description</b>        |
|-----------------------------------------------------------------------------------------|-------------|---------------------------|
| 9:0                                                                                     | FRACDIV     | <b>Fractional divisor</b> |
| Note: effective only when SPEED = 3. Add sampling count (+1) for corresponding data bit |             |                           |

---

| <b>AooCoo5C RX_TO_CON</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>RX timeout mode control</b> |                      |  |  |
|---------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------------------|----------------------|--|--|
| <b>Bit</b>                | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                             |                      |  |  |
| <b>Name</b>               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                |                      |  |  |
| <b>Type</b>               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                |                      |  |  |
| <b>Reset</b>              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                |                      |  |  |
| <b>Bit</b>                | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                              |                      |  |  |
| <b>Name</b>               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                | <b>TO_CNT_AUTOST</b> |  |  |
| <b>Type</b>               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                | <b>RW</b>            |  |  |
| <b>Reset</b>              |    |    |    |    |    |    |    |    |    |    |    |    | 0  |    |    |                                | 0                    |  |  |

---

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b> |
|---------------|-------------|--------------------|
|---------------|-------------|--------------------|

---

---

|   |                |                                                                                                                                                                                       |
|---|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8 | TO_CNT_AUTORST | <b>Time-out counter auto reset</b>                                                                                                                                                    |
|   |                | <ul style="list-style-type: none"> <li>0: Reset the RX timeout interrupt manually (see IIR for detailed information)</li> <li>1: RX timeout counter is reset automatically</li> </ul> |
| 0 | RX_TO_MODE     | <b>RX timeout mode</b>                                                                                                                                                                |
|   |                | <ul style="list-style-type: none"> <li>0: Timeout when RX idle for 4 characters</li> <li>1: Timeout when RX idle for a certain period of time (defined by RX_TOC_DEST)</li> </ul>     |

---

| <b>AooCoo6o RX TOC DEST</b> |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-----------------------------|--------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Bit</b>                  | 31                 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b>                 |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                 |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Bit</b>                  | 15                 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>                 | <b>RX_TOC_DEST</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                 | RW                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                | 1                  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  |    |

---

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                                                 |
|---------------|-------------|------------------------------------------------------------------------------------|
| 15:0          | RX_TOC_DEST | RX timeout counter destination value<br>Note: effective only when RX_TO_CON[0] = 1 |

---

## 6. Serial Peripheral Interface Master Controller

The Serial Peripheral Interface (SPI) is a bit-serial transmission protocol. MT7682 supports single mode (four-pin), dual mode (four-pin) and quad mode (six-pin) for increased data throughput. The maximum serial clock (SCK) frequency is 48MHz. Note that the single mode can support full duplex, but dual quad mode only supports half-duplex. Figure 5.5-1 is an example of the connection between the SPI master and SPI slave. The SPI controller is a master responsible for data transmission with slave.



**Figure 5.5-1. Pin connection between SPI master and SPI slave**

**Table 5.5-1. SPI master controller interface**

| Signal name | Type | Default value     | Description                                          |
|-------------|------|-------------------|------------------------------------------------------|
| CS          | O    | 1 (output)        | Low active chip selection signal                     |
| SCK         | O    | 0 (output)        | The (bit) serial clock (Max SCK clock rate is 48MHz) |
| SIO0        | I/O  | 1 (output)        | Data signal 0                                        |
| SIO1        | I/O  | pull down (input) | Data signal 1                                        |
| SIO2        | I/O  | 1 (output)        | Data signal 2                                        |
| SIO3        | I/O  | 1 (output)        | Data signal 3                                        |

### 6.1. Features

- The SPI master controller supports single mode (four-pin), dual mode (four-pin) and quad mode (six-pin). The controller can automatically set port direction for data input/output if registers SPIM\_TYPE and SPIM\_RW\_MODE are already set.
- The SCK frequency supports maximum 48MHz with CPOL and CPHA features and can be configured as 96/N MHz (where N is from 2 to 2<sup>17</sup>) for different applications. CPOL defines the clock polarity in the transmission. CPHA defines the legal timing to sample data. The chip select (CS) signal setup time, hold time and idle time can be configured, too. The detailed timing diagram of the SCK and CS signals is shown in Figure 6.1-1.
- There are two configurable modes for the source of the transfer data:
  - DMA mode, the SPI master controller includes the DMA design, it can automatically read or write data from memory continuously;
  - Direct mode, the CPU directly reads data from the SPI master controller FIFO or writes data to the SPI master controller FIFO. In DMA mode, the endian order of memory data is adjustable.



**Figure 6.1-1. SPI transmission formats**

- Unlimited length for transmission can be achieved in Pause mode. In Pause mode, the CS signal will stay active (low) after the transmission. During this period, the SPI controller will be in **PAUSE\_IDLE** state, ready to receive the resume command. Figure 6.1-2 is the state transition diagram.



**Figure 6.1-2. Operation flow with or without PAUSE mode**

- A configurable option to control CS de-assertion between byte transfers is available. The SPI master controller supports a special transmission format called CS de-assert mode. Figure 6.1-3 illustrates the waveform in this transmission format.



**Figure 6.1-3. CS de-assert mode**

- When the SPI master controller operates in dual or quad mode, the transmission package includes three parts: command phase, dummy phase and data phase.
  - Command phase always operates at Single mode;
  - Dummy phase cannot transmit or receive data;
  - Data phase operation depends on **SPIM\_TYPE** and **SPIM\_RW\_MODE** settings. The Command phase and Dummy phase are useful for special applications, such as read or write serial flash data.

- For high-speed transmission, the SPI master controller can enable the delay sample feature (registers **SPIM\_GET\_DLY** and **SAMPLE\_SEL**) to resolve data path latency issues. The critical path of SPI transmission includes two parts:
  - Master transmits SCK signal to slave;
  - Slave feeds back SIO data to master. Each interval of sample delay is 10.42 ns, and **SAMPLE\_SEL** defines the trigger edge of sample clock, such as, if 0 - positive edge sample data; 1 - negative edge sample data. The detailed description is shown in Figure 6.1-4.



Figure 6.1-4. SPI master controller delay sample

## 6.2. Block diagram



Figure 6.2-1. Block diagram of SPI master controller

## 6.3. Functions

- SPI master single mode. Typical SPI transmission mode is single SPI, a 4-pin protocol. Set the register **SPIM\_TYPE** to 0 to enter single mode. In this mode, the register settings for **SPIM\_RW\_MODE**, **SPIM\_DUMMY\_CNT** and **SPIM\_COMMAND\_CNT** are not supported. The single mode data transmission diagram is shown in Figure 6.3-1.



**Figure 6.3-1. SPI master single mode**

- SPI master dual mode. The dual mode SPI is also a 4-pin protocol. Set the register **SPIM\_TYPE** to 1 to enter this mode. In dual mode, the SPI master controller only supports half duplex, and the data transmission direction is configured by register **SPIM\_RW\_MODE** (0: read data, 1: write data). The registers **SPIM\_DUMMY\_CNT**, **SPIM\_COMMAND\_CNT** can be activated with user configuration. In addition, **SPIM\_DUMMY\_CNT** and **SPIM\_COMMAND\_CNT** can be set to 0 to disable these features. The dual mode data transmission diagram is shown in Figure 6.3-2 and Figure 6.3-3.



**Figure 6.3-2. SPI master dual mode write data**



**Figure 6.3-3. SPI master dual mode read data**

- SPI master quad mode. The quad mode SPI is a 6-pin protocol. Set the register **SPIM\_TYPE** to 2 to enter this mode. Similar to dual mode, in quad mode, the SPI master controller only supports half duplex, and the data transmission direction is configured by register **SPIM\_RW\_MODE** (0: read data, 1: write data). The registers **SPIM\_DUMMY\_CNT**, **SPIM\_COMMAND\_CNT** can also be activated. The quad mode data transmission diagram is shown in Figure 6.3-4 and Figure 6.3-5.



**Figure 6.3-4. SPI master quad mode write data**



Figure 6.3-5. SPI master quad mode read data

## 6.4. Register mapping

Module name: SPI\_MASTER Base address: (+AooAooooh)

| Address  | Name                  | Width | Register Function                                 |
|----------|-----------------------|-------|---------------------------------------------------|
| AooAoooo | <b>SPIMST_CTRL0</b>   | 32    | <b>SPI Master Control 0 Register</b>              |
| AooAooo4 | <b>SPIMST_CTRL1</b>   | 32    | <b>SPI Master Control 1 Register</b>              |
| AooAooo8 | <b>SPIMST_TRIG</b>    | 32    | <b>SPI Master Trigger Register</b>                |
| AooAoooC | <b>SPIMST_IE</b>      | 32    | <b>SPI Master Interrupt Enable</b>                |
| AooAoo10 | <b>SPIMST_INT</b>     | 32    | <b>SPI Master Interrupt</b>                       |
| AooAoo14 | <b>SPIMST_STA</b>     | 32    | <b>SPI Master Status</b>                          |
| AooAoo18 | <b>SPIMST_TX_DATA</b> | 32    | <b>SPI Master TX Data</b>                         |
| AooAoo1C | <b>SPIMST_RX_DATA</b> | 32    | <b>SPI Master RX Data</b>                         |
| AooAoo20 | <b>SPIMST_TX_SRC</b>  | 32    | <b>SPI Master TX Source Address Register</b>      |
| AooAoo24 | <b>SPIMST_RX_DST</b>  | 32    | <b>SPI Master RX Destination Address Register</b> |
| AooAoo28 | <b>SPIMST_CFG0</b>    | 32    | <b>SPI Master Configuration 0 Register</b>        |
| AooAoo2C | <b>SPIMST_CFG1</b>    | 32    | <b>SPI Master Configuration 1 Register</b>        |
| AooAoo30 | <b>SPIMST_CFG2</b>    | 32    | <b>SPI Master Configuration 2 Register</b>        |
| AooAoo34 | <b>SPIMST_CFG3</b>    | 32    | <b>SPI Master Configuration 3 Register</b>        |
| AooAoo38 | <b>SPIMST_DLYSEL0</b> | 32    | <b>SPI Master Delay Select 0 Register</b>         |
| AooAoo3C | <b>SPIMST_DLYSEL1</b> | 32    | <b>SPI Master Delay Select 1 Register</b>         |
| AooAoo40 | <b>SPIMST_DLYSEL2</b> | 32    | <b>SPI Master Delay Select 2 Register</b>         |

| SPIMST_CTRL |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0  | SPI Master Control 0 Register | 00000000 |  |
|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------------------|----------|--|
| Bit         | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |                               |          |  |
| Name        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | SPI_M_PA_US_E_EN              |          |  |
| Type        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW                            |          |  |
| Reset       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0                             |          |  |
| Bit         | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |                               |          |  |

| SPIMST_CTRL |  |  |  |  |  |  |  |  |  | SPI Master Control 0 Register           |            |   |   |   |   |   |   | 00000000 |   |   |   |   |   |   |   |
|-------------|--|--|--|--|--|--|--|--|--|-----------------------------------------|------------|---|---|---|---|---|---|----------|---|---|---|---|---|---|---|
| <u>0</u>    |  |  |  |  |  |  |  |  |  |                                         |            |   |   |   |   |   |   |          |   |   |   |   |   |   |   |
| Name        |  |  |  |  |  |  |  |  |  | SPI<br>M<br>DE<br>ASS<br>ER<br>T_E<br>N | SPIM_CTRL0 |   |   |   |   |   |   |          |   |   |   |   |   |   |   |
| Type        |  |  |  |  |  |  |  |  |  | RW                                      |            |   |   |   |   |   |   | RW       |   |   |   |   |   |   |   |
| Reset       |  |  |  |  |  |  |  |  |  | o                                       | o          | o | o | o | o | o | o | o        | o | o | o | o | o | o | o |

| Bit(s) | Name             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16     | SPIM_PAUSE_EN    | <b>Pause mode enable</b><br>Set the pause mode bit to 1 to enable this mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 8      | SPIM_DEASSERT_EN | <b>De-assert mode enable</b><br>Enable bit of the chip select de-assertion mode. Set it to 1 to enable this mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 6:0    | SPIM_CTRL0       | <b>SPI master general configure set 0</b> <ul style="list-style-type: none"> <li>[6]: SPIM_RW_MODE, indicates SPI master received/sent data, only used in Dual/Quad SPI (SPIM_TYPE = 1 or 2).           <ul style="list-style-type: none"> <li>o: Read mode, SPI master receive data</li> <li>1: Write mode, SPI master send data</li> </ul> </li> <li>[5:4]: SPIM_TYPE, indicates the SPI data transmission type           <ul style="list-style-type: none"> <li>o: Single SPI</li> <li>1: Dual SPI</li> <li>2: Quad SPI</li> <li>3: Not used</li> </ul> </li> <li>[3]: RXMSBF, indicates the RX data received is MSB first or not. Set RXMSBF to 1 for MSB first, otherwise set it to 0.</li> <li>[2]: TXMSBF, indicates the TX data sent is MSB first or not. Set TXMSBF to 1 for MSB first, otherwise set it to 0.</li> <li>[1]: CPOL, control bit of the SCK polarity.           <ul style="list-style-type: none"> <li>o: CPOL = 0</li> <li>1: CPOL = 1</li> </ul> </li> <li>[0]: CPHA, control bit of the SCK sample data phase.           <ul style="list-style-type: none"> <li>o: CPHA = 0</li> <li>1: CPHA = 1</li> </ul> </li> </ul> |

| SPIMST_CTRL |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | SPI Master Control 1 Register |                                 |  |  |  |  |  |  | 00000000 |            |  |  |  |  |  |  |  |
|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------------------|---------------------------------|--|--|--|--|--|--|----------|------------|--|--|--|--|--|--|--|
| <u>1</u>    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                               |                                 |  |  |  |  |  |  |          |            |  |  |  |  |  |  |  |
| Bit         | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                            | SPI<br>M<br>TX<br>DM<br>A<br>EN |  |  |  |  |  |  |          |            |  |  |  |  |  |  |  |
| Name        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW                            |                                 |  |  |  |  |  |  |          | RW         |  |  |  |  |  |  |  |
| Type        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | o                             |                                 |  |  |  |  |  |  |          | o          |  |  |  |  |  |  |  |
| Bit         | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                             |                                 |  |  |  |  |  |  |          | SPIM_CTRL1 |  |  |  |  |  |  |  |
| Name        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW                            |                                 |  |  |  |  |  |  |          | RW         |  |  |  |  |  |  |  |
| Type        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                               |                                 |  |  |  |  |  |  |          |            |  |  |  |  |  |  |  |

| AooAooo4    |   |   |   |   |   |   |   |   |   | SPI Master Control 1 Register |   |   |   |   |   |   |   |   |   | 00000000 |   |   |   |   |   |   |   |   |   |
|-------------|---|---|---|---|---|---|---|---|---|-------------------------------|---|---|---|---|---|---|---|---|---|----------|---|---|---|---|---|---|---|---|---|
| SPIMST_CTRL |   |   |   |   |   |   |   |   |   | 1                             |   |   |   |   |   |   |   |   |   |          |   |   |   |   |   |   |   |   |   |
| Reset       | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                             | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0        | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| Bit(s) | Name          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24     | SPIM_RXDMA_EN | <b>RX DMA enable</b><br>DMA mode enable bit of the data being received. Default (0) is not to enable.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 16     | SPIM_TXDMA_EN | <b>TX DMA enable</b><br>DMA mode enable bit of the data to be transmitted. Default (0) is not to enable.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 10:8   | SPIM_GET_DLY  | <b>Receive data get delay</b><br>If the latency of the signal that SPI master received is too large, the register can help to tolerate get_tick timing. The timing is CLK_PERIOD (10.42ns) * SPIM_GET_DLY.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 3:0    | SPIM_CTRL1    | <b>SPI master general configure set 1</b> <ul style="list-style-type: none"> <li>[3]: RX_ENDIAN, defines whether to reverse the endian order of the data DMA to memory. Default (0) is not to reverse.           <ul style="list-style-type: none"> <li>0: RX data format is data[31:0]</li> <li>1: RX data format is {data[7:0], data[15:8], data[23:16], data[31:24]}</li> </ul> </li> <li>[2]: TX_ENDIAN, defines whether to reverse the endian order of the data DMA from memory. Default (0) is not to reverse.           <ul style="list-style-type: none"> <li>0: TX data format is data[31:0]</li> <li>1: TX data format is {data[7:0], data[15:8], data[23:16], data[31:24]}</li> </ul> </li> <li>[1]: CS_POL, control bit of chip select polarity           <ul style="list-style-type: none"> <li>0: Active low</li> <li>1: Active high</li> </ul> </li> <li>[0]: SAMPLE_SEL, control bit of sample edge of RX data           <ul style="list-style-type: none"> <li>0: Positive edge</li> <li>1: Negative edge</li> </ul> </li> </ul> |

| AooAooo8 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | SPIMST_TRIG |  |  |  |  |  |  |  |  |  | 00000000 |  |  |  |  |  |  |  |  |  |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------|--|--|--|--|--|--|--|--|--|----------|--|--|--|--|--|--|--|--|--|
| Bit      | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16          |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |
| Name     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |             |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |
| Type     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |             |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |
| Reset    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |             |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |
| Bit      | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0           |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |
| Name     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |             |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |
| Type     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |             |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |
| Reset    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |             |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |

| Bit(s) | Name     | Description                                                                                                                                                                         |
|--------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16     | SPIM_RST | <b>Reset</b><br>Software reset bit; resets the state machine and data FIFO of SPI master controller (not the register value). When this bit is 1, software reset is active high and |

---

|   |              |                                                                                                                                                                        |
|---|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |              | hardware can automatically return to 0. The default value is 0.                                                                                                        |
| 8 | SPIM_RESUME  | <b>Resume</b><br>This bit is used when the controller is in PAUSE IDLE state. Write 1 to this bit to trigger the SPI controller resume transfer from PAUSE IDLE state. |
| 0 | SPIM_CMD_ACT | <b>Command activate</b><br>Write 1 to this bit to trigger the SPI master controller to start the transmission.                                                         |

---

| AooAoooC     |    | <b>SPIMST IE</b> |    |    |    |    |    |    |    |    |    |    |    |    |    | SPI Master Interrupt Enable |  |  |  |
|--------------|----|------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------|--|--|--|
| Bit          | 31 | 30               | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                          |  |  |  |
| <b>Name</b>  |    |                  |    |    |    |    |    |    |    |    |    |    |    |    |    |                             |  |  |  |
| <b>Type</b>  |    |                  |    |    |    |    |    |    |    |    |    |    |    |    |    |                             |  |  |  |
| <b>Reset</b> |    |                  |    |    |    |    |    |    |    |    |    |    |    |    |    |                             |  |  |  |
| <b>Bit</b>   | 15 | 14               | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                           |  |  |  |
| <b>Name</b>  |    |                  |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>SPIM IE</b>              |  |  |  |
| <b>Type</b>  |    |                  |    |    |    |    |    |    |    |    |    |    |    |    |    | RW                          |  |  |  |
| <b>Reset</b> |    |                  |    |    |    |    |    |    |    |    |    |    |    |    |    | 0                           |  |  |  |

---

| Bit(s) | Name    | Description                                                                                                                                                                                           |
|--------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0    | SPIM_IE | <b>SPI master interrupt source enable</b><br>[1]: PAUSE_IE, interrupt enable bit of pause flag in SPI status register.<br>[0]: FINISH_IE, interrupt enable bit of finish flag in SPI status register. |

---

| A00A0010     |    | <b>SPIMST INT</b> |    |    |    |    |    |    |    |    |    |    |    |    |    | SPI Master Interrupt |  |  |  |
|--------------|----|-------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------------|--|--|--|
| Bit          | 31 | 30                | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                   |  |  |  |
| <b>Name</b>  |    |                   |    |    |    |    |    |    |    |    |    |    |    |    |    |                      |  |  |  |
| <b>Type</b>  |    |                   |    |    |    |    |    |    |    |    |    |    |    |    |    |                      |  |  |  |
| <b>Reset</b> |    |                   |    |    |    |    |    |    |    |    |    |    |    |    |    |                      |  |  |  |
| <b>Bit</b>   | 15 | 14                | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                    |  |  |  |
| <b>Name</b>  |    |                   |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>SPIM INT</b>      |  |  |  |
| <b>Type</b>  |    |                   |    |    |    |    |    |    |    |    |    |    |    |    |    | RC                   |  |  |  |
| <b>Reset</b> |    |                   |    |    |    |    |    |    |    |    |    |    |    |    |    | 0                    |  |  |  |

---

| Bit(s) | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0    | SPIM_INT | <b>SPI master interrupt source</b> <ul style="list-style-type: none"> <li>[1]: PAUSE_INT, interrupt status bit in pause mode. It will be set by the SPI controller when it completes the transaction, entering the PAUSE IDLE state.</li> <li>[0]: FINISH_INT, interrupt status bit in non-pause mode. It will be set by the SPI controller when it completes the transaction, entering the IDLE state.</li> </ul> |

---

| A00A0014     |    | <b>SPIMST STA</b> |    |    |    |    |    |    |    |    |    |    |    |    |    | SPI Master Status  |  |  |  |
|--------------|----|-------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------|--|--|--|
| Bit          | 31 | 30                | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                 |  |  |  |
| <b>Name</b>  |    |                   |    |    |    |    |    |    |    |    |    |    |    |    |    |                    |  |  |  |
| <b>Type</b>  |    |                   |    |    |    |    |    |    |    |    |    |    |    |    |    |                    |  |  |  |
| <b>Reset</b> |    |                   |    |    |    |    |    |    |    |    |    |    |    |    |    |                    |  |  |  |
| <b>Bit</b>   | 15 | 14                | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                  |  |  |  |
| <b>Name</b>  |    |                   |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>SPI M BU SY</b> |  |  |  |
| <b>Type</b>  |    |                   |    |    |    |    |    |    |    |    |    |    |    |    |    | RO                 |  |  |  |
| <b>Reset</b> |    |                   |    |    |    |    |    |    |    |    |    |    |    |    |    | 0                  |  |  |  |

---

| Bit(s) | Name | Description |
|--------|------|-------------|
|--------|------|-------------|

---

0 SPI\_MBUSY

**SPI master status**

This status flag reflects whether the SPI controller is busy. This bit is high active, i.e. 1 represents the SPI controller is currently busy. The state diagram is shown in Figure 6.1-2. Operation flow with or without PAUSE modeFigure 6.1-2.

- 1'b1: busy
- 1'bo: idle

AooAoo18 [SPIMST\\_TX\\_D](#) SPI Master TX Data 00000000  
ATA

| Bit          | 31                                         | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|--------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  | <u><a href="#">SPIM_TX_DATA[31:16]</a></u> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | WO                                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                                          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>   | 15                                         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | <u><a href="#">SPIM_TX_DATA[15:0]</a></u>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | WO                                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                                          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**Bit(s)** Bit(s) **Name** Name **Description** Description

31:0 SPI\_MTXDATA SPI\_MTXDATA

**TX data**

The depth of the TX FIFO is 32 bytes. Write to this register to write 4 bytes into TX FIFO. The TX FIFO pointer will automatically move toward to the next four bytes.

AooAoo1C [SPIMST\\_RX\\_D](#) SPI Master RX Data 00000000  
ATA

| Bit          | 31                                         | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|--------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  | <u><a href="#">SPIM_RX_DATA[31:16]</a></u> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RO                                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                                          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>   | 15                                         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | <u><a href="#">SPIM_RX_DATA[15:0]</a></u>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RO                                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                                          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**Bit(s)** Bit(s) **Name** Name **Description** Description

31:0 SPI\_MRXDATA SPI\_MRXDATA

**RX data**

The depth of the RX FIFO is 32 bytes. Read from this register to read 4 bytes from the RX FIFO. The RX FIFO pointer will automatically move toward to the next four bytes.

AooAoo20 [SPIMST\\_TX\\_S](#) SPI Master TX Source Address Register 00000000  
RC

| Bit          | 31                                        | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|-------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  | <u><a href="#">SPIM_TX_SRC[31:16]</a></u> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW                                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                                         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>   | 15                                        | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | <u><a href="#">SPIM_TX_SRC[15:0]</a></u>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW                                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                                         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name        | Description                                                                                                                                                                                                                           |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | SPIM_TX_SRC | <b>TX data source address</b><br>SPIM_TX_SRC defines the memory address from which the SPI controller reads transmitted data. The address must be aligned with the word boundary. Note, the SPI master cannot read serial flash data. |

AooAoo24 SPIMST\_RX\_D SPI Master RX Destination Address Register 00000000  
ST

| Bit          | 31                        | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|---------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  | <b>SPIM_RX_DST[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>   | 15                        | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | <b>SPIM_RX_DST[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name        | Description                                                                                                                                                                                                                      |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | SPIM_RX_DST | <b>RX data destination address</b><br>SPI_RX_DST defines the memory address to which the SPI controller stores the data. The address must be aligned with the word boundary. Note, the SPI master cannot read serial flash data. |

AooAoo28 SPIMST\_CFG0 SPI Master Configuration 0 Register 00000000

| Bit          | 31                       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|--------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  | <b>SPIM_CS_SETUP_CNT</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>   | 15                       | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | <b>SPIM_CS_HOLD_CNT</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name              | Description                                                                                                                                                        |
|--------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16  | SPIM_CS_SETUP_CNT | <b>Chip select setup time</b><br>Setup time = (SPIM_CS_SETUP_CNT+1) * CLK_PERIOD, where CLK_PERIOD (10.42ns) is the cycle time of the clock the SPI engine adopts. |
| 15:0   | SPIM_CS_HOLD_CNT  | <b>Chip select hold time</b><br>Hold time = (SPIM_CS_HOLD_COUNT+1) * CLK_PERIOD, where CLK_PERIOD (10.42ns) is the cycle time of the clock the SPI engine adopts.  |

AooAoo2C SPIMST\_CFG1 SPI Master Configuration 1 Register 00000000

| Bit          | 31                       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|--------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  | <b>SPIM_SCK_LOW_CNT</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>   | 15                       | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | <b>SPIM_SCK_HIGH_CNT</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name | Description |
|--------|------|-------------|
|--------|------|-------------|

|       |                   |                                                                                                   |
|-------|-------------------|---------------------------------------------------------------------------------------------------|
| 31:16 | SPIM_SCK_LOW_CNT  | <b>SPI master clock low time</b><br>SCK low time = (SPIM_SCK_LOW_CNT+1) * CLK_PERIOD (10.42ns)    |
| 15:0  | SPIM_SCK_HIGH_CNT | <b>SPI master clock high time</b><br>SCK high time = (SPIM_SCK_HIGH_CNT+1) * CLK_PERIOD (10.42ns) |

| <b>Bit(s)</b> | <b>Name</b>            | <b>Description</b>                                                                                                                                                                        |
|---------------|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16         | SPIM_PACKET_LENGTH_CNT | <b>Transmission package length</b><br>The number of bytes in one packet = PACKET_LENGTH_CNT + 1.<br>Total number bytes of one transmission = (PACKET_LENGTH_CNT+1) * (PACKET_LOOP_CNT+1). |
| 15:8          | SPIM_PACKET_LOOP_CNT   | <b>Transmission loop times</b><br>The number of packets in one transmission = PACKET_LOOP_CNT + 1.                                                                                        |
| 7:0           | SPIM_CS_IDLE_CNT       | <b>Chip select idle time</b><br>Time between consecutive transmissions = (CS_HOLD_COUNT+1) * CLK_PERIOD.                                                                                  |

| AooAoo34 |    | <u>SPIMST_CFG3</u> |    | SPI Master Configuration 3 Register |    |    |    |    |    |    |    |    |                         |    |    | 00000000 |  |  |  |
|----------|----|--------------------|----|-------------------------------------|----|----|----|----|----|----|----|----|-------------------------|----|----|----------|--|--|--|
| Bit      | 31 | 30                 | 29 | 28                                  | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19                      | 18 | 17 | 16       |  |  |  |
| Name     |    |                    |    |                                     |    |    |    |    |    |    |    |    |                         |    |    |          |  |  |  |
| Type     |    |                    |    |                                     |    |    |    |    |    |    |    |    |                         |    |    |          |  |  |  |
| Reset    |    |                    |    |                                     |    |    |    |    |    |    |    |    |                         |    |    |          |  |  |  |
| Bit      | 15 | 14                 | 13 | 12                                  | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3                       | 2  | 1  | 0        |  |  |  |
| Name     |    |                    |    | <u>SPIM_DUMMY_CNT</u>               |    |    |    |    |    |    |    |    | <u>SPIM_COMMAND_CNT</u> |    |    |          |  |  |  |
| Type     |    |                    |    | RW                                  |    |    |    |    |    |    |    |    | RW                      |    |    |          |  |  |  |
| Reset    |    |                    |    | 0                                   | 0  | 0  | 0  |    |    |    |    |    | 0                       | 0  | 0  | 0        |  |  |  |

| <b>Bit(s)</b> | <b>Name</b>      | <b>Description</b>                                                                                                                                                                                                                                                 |
|---------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:8          | SPIM_DUMMY_CNT   | <p><b>Dummy count</b></p> <p>The number of dummy bits in one packet. Dummy phase is the second transmission of packet between command phase and data phase. Dummy phase cannot transmit or receive data, it's only used in Dual/Quad SPI (SPIM_TYPE = 1 or 2).</p> |
| 3:0           | SPIM_COMMAND_CNT | <p><b>Command count</b></p> <p>The number of command bytes in one packet. Command phase is the first transmission of packet before dummy phase and data phase. The command phase is used in Dual/Quad SPI (SPIM_TYPE = 1 or 2).</p>                                |

| SPI Master Delay Select o Register |    |                    |    |          |    |    |                     |    |    |    |    |    |    |                     |    |    |
|------------------------------------|----|--------------------|----|----------|----|----|---------------------|----|----|----|----|----|----|---------------------|----|----|
| AooAoo38                           |    | <u>SPIMST_DLYS</u> |    | 00000000 |    |    |                     |    |    |    |    |    |    |                     |    |    |
|                                    |    | <u>ELO</u>         |    |          |    |    |                     |    |    |    |    |    |    |                     |    |    |
| Bit                                | 31 | 30                 | 29 | 28       | 27 | 26 | 25                  | 24 | 23 | 22 | 21 | 20 | 19 | 18                  | 17 | 16 |
| Name                               |    |                    |    |          |    |    | <u>SPIM_MOSI3_D</u> |    |    |    |    |    |    | <u>SPIM_MOSI2_D</u> |    |    |

AooAoo38 **SPIMST\_DLYS** SPI Master Delay Select 0 Register 00000000  
**EL0**

| <b>Type</b>  | LYSEL                    |    |    |       |    |    |       |   |   |       |   |   | <b>LYSEL</b>             |   |   |   |
|--------------|--------------------------|----|----|-------|----|----|-------|---|---|-------|---|---|--------------------------|---|---|---|
|              | RW                       |    |    | 0 0 0 |    |    | RW    |   |   | 0 0 0 |   |   |                          |   |   |   |
| <b>Reset</b> | 15                       | 14 | 13 | 12    | 11 | 10 | 9     | 8 | 7 | 6     | 5 | 4 | 3                        | 2 | 1 | 0 |
| <b>Name</b>  | <b>SPIM_MOSI3_DLYSEL</b> |    |    |       |    |    |       |   |   |       |   |   | <b>SPIM_MOSIo_DLYSEL</b> |   |   |   |
| <b>Type</b>  | RW                       |    |    |       |    |    |       |   |   |       |   |   | RW                       |   |   |   |
| <b>Reset</b> | 0 0 0                    |    |    | 0 0 0 |    |    | 0 0 0 |   |   | 0 0 0 |   |   | 0 0 0                    |   |   |   |

| <b>Bit(s)</b> | <b>Name</b>       | <b>Description</b>                                                                                                          |
|---------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------|
| 26:24         | SPIM_MOSI3_DLYSEL | <b>MOSI3 delay select</b><br>The register can configure MOSI3 output signal delay. The delay is SPIM_MOSI3_DLYSEL * 1.5 ns. |
| 18:16         | SPIM_MOSI2_DLYSEL | <b>MOSI2 delay select</b><br>The register can configure MOSI2 output signal delay. The delay is SPIM_MOSI2_DLYSEL * 1.5 ns. |
| 10:8          | SPIM_MOSI1_DLYSEL | <b>MOSI1 delay select</b><br>The register can configure MOSI1 output signal delay. The delay is SPIM_MOSI1_DLYSEL * 1.5 ns. |
| 2:0           | SPIM_MOSIo_DLYSEL | <b>MOSIo delay select</b><br>The register can configure MOSIo output signal delay. The delay is SPIM_MOSIo_DLYSEL * 1.5 ns. |

AooAoo3C **SPIMST\_DLYS** SPI Master Delay Select 1 Register 00000000  
**EL1**

| <b>Bit</b>   | 31                       | 30                       | 29 | 28    | 27 | 26                       | 25                       | 24 | 23 | 22    | 21 | 20                       | 19                       | 18 | 17 | 16 |  |
|--------------|--------------------------|--------------------------|----|-------|----|--------------------------|--------------------------|----|----|-------|----|--------------------------|--------------------------|----|----|----|--|
|              | <b>Name</b>              | <b>SPIM_MISO3_DLYSEL</b> |    |       |    |                          | <b>SPIM_MISO2_DLYSEL</b> |    |    |       |    |                          | <b>SPIM_MISO1_DLYSEL</b> |    |    |    |  |
| <b>Type</b>  | RW                       |                          |    |       |    |                          |                          |    |    |       |    |                          | RW                       |    |    |    |  |
| <b>Reset</b> | 0 0 0                    |                          |    | 0 0 0 |    |                          | 0 0 0                    |    |    | 0 0 0 |    |                          | 0 0 0                    |    |    |    |  |
|              | 15                       | 14                       | 13 | 12    | 11 | 10                       | 9                        | 8  | 7  | 6     | 5  | 4                        | 3                        | 2  | 1  | 0  |  |
| <b>Name</b>  | <b>SPIM_MISO3_DLYSEL</b> |                          |    |       |    | <b>SPIM_MISO2_DLYSEL</b> |                          |    |    |       |    | <b>SPIM_MISO1_DLYSEL</b> |                          |    |    |    |  |
| <b>Type</b>  | RW                       |                          |    |       |    |                          |                          |    |    |       |    |                          | RW                       |    |    |    |  |
| <b>Reset</b> | 0 0 0                    |                          |    | 0 0 0 |    |                          | 0 0 0                    |    |    | 0 0 0 |    |                          | 0 0 0                    |    |    |    |  |

| <b>Bit(s)</b> | <b>Name</b>       | <b>Description</b>                                                                                                         |
|---------------|-------------------|----------------------------------------------------------------------------------------------------------------------------|
| 26:24         | SPIM_MISO3_DLYSEL | <b>MISO3 delay select</b><br>The register can configure MISO3 input signal delay. The delay is SPIM_MISO3_DLYSEL * 1.5 ns. |
| 18:16         | SPIM_MISO2_DLYSEL | <b>MISO2 delay select</b><br>The register can configure MISO2 input signal delay. The delay is SPIM_MISO2_DLYSEL * 1.5 ns. |
| 10:8          | SPIM_MISO1_DLYSEL | <b>MISO1 delay select</b><br>The register can configure MISO1 input signal delay. The delay is SPIM_MISO1_DLYSEL * 1.5 ns. |
| 2:0           | SPIM_MISOo_DLYSEL | <b>MISOo delay select</b><br>The register can configure MISOo input signal delay. The delay is SPIM_MISOo_DLYSEL * 1.5 ns. |

| <u><b>SPIMST_DLYS</b></u> |                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |                         |
|---------------------------|------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|-------------------------|
| AooAoo40                  | SPI Master Delay Select 2 Register |    |    |    |    |    |    |    |    |    |    |    |    |    | oooooooo |                         |
| <u><b>EL2</b></u>         |                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |                         |
| <b>Bit</b>                | 31                                 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17       | 16                      |
| <b>Name</b>               |                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |                         |
| <b>Type</b>               |                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |                         |
| <b>Reset</b>              |                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |                         |
| <b>Bit</b>                | 15                                 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1        | 0                       |
| <b>Name</b>               |                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |          | <b>SPIM_SCK_DLY_SEL</b> |
| <b>Type</b>               |                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |          | RW                      |
| <b>Reset</b>              |                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |          | 0 0 0                   |

| <b>Bit(s)</b> | <b>Name</b>            | <b>Description</b>                                                                         |
|---------------|------------------------|--------------------------------------------------------------------------------------------|
| 2:0           | <b>SPIM_SCK_DLYSEL</b> | <b>SCK delay select</b>                                                                    |
|               |                        | The register can configure SCK output signal delay. The delay is SPIM_SCK_DLYSEL * 1.5 ns. |

## 7. Serial Peripheral Interface Slave Controller

The Serial Peripheral Interface (SPI) is a bit-serial transmission protocol. MT7682 supports single mode (four-pin), dual mode (four-pin) and quad mode (six-pin) to increase data throughput. The maximum serial clock (SCK) frequency is 48MHz. Figure 6.4-1 is an example of the connection between the SPI master and SPI slave. The SPI controller is a slave responsible for data transmission with master.



**Figure 6.4-1. Pin connection between SPI master and SPI slave**

**Table 6.4-1. SPI slave controller interface**

| Signal name | Type | Default value     | Description                                          |
|-------------|------|-------------------|------------------------------------------------------|
| CS          | I    | pull up (input)   | Low active chip selection signal                     |
| SCK         | I    | pull down (input) | The (bit) serial clock (Max SCK clock rate is 48MHz) |
| SIO0        | I/O  | pull down (input) | Data signal 0                                        |
| SIO1        | I/O  | 0 (output)        | Data signal 1                                        |
| SIO2        | I/O  | pull down (input) | Data signal 2                                        |
| SIO3        | I/O  | pull down (input) | Data signal 3                                        |

### 7.1. Features

- The SPI slave controller supports single mode (four-pin), dual mode (four-pin) and quad mode (six-pin). The controller can automatically set port direction for data input/output if register **SPIM\_TYPE** is set.
- Each databyte transmit/receive sequence can be configured separately with registers **TXMSBF** and **RXMSBF**.
- The memory address of the SPI slave controller's internal DMA read/write data can be configured by two methods: SPI master command (hardware) configure and software configure.
  - When register **SPIS\_DEC\_ADDR\_EN** is 0, enable hardware configuration feature. The address of DMA read/write is the SPI master CR/CW configuration address and **SPISLV\_BUFFER\_BASE\_ADDR**. For example, if the SPI master CR address is 0x1000 and **SPISLV\_BUFFER\_BASE\_ADDR** is 0x2500, the address of DMA read/write will be 0x3500.
  - When register **SPIS\_DEC\_ADDR\_EN** is 1, enable software configuration feature. The SPI master DMA reads and writes data from the address **SPISLV\_BUFFER\_BASE\_ADDR**.
- The serial clock frequency supports maximum of 48MHz with CPOL and CPHA features. CPOL defines the clock polarity in the transmission. CPHA defines the legal timing to sample data. The detailed timing diagram of the SCK and CS signal is shown in Figure 7.1-1.



Figure 7.1-1. SPI transmission formats

- For high-speed transmission, the SPI slave controller can enable early transmission feature (register) to resolve data path latency issue. The detailed description is shown in Figure 7.1-2.



Figure 7.1-2. SPI slave controller early transmit

## 7.2. Block diagram



Figure 7.2-1. Block diagram of SPI slave controller

- The SPI slave controller accesses memory through the AHB interface and the CPU can access the SPI slave controller through the APB interface.
- The SPI slave controller has an internal direct memory access (DMA) engine to access memory and FIFO to store data during transmission.
- The SPI slave controller can set the direction (in or out) of GPIO pinmux by SIO\_oe (defined by SPIM\_TYPE).

## 7.3. Functions

The SPI slave controller has nine commands that can be configured by the SPI master transmit data, the command set is shown in Table 7.3-1 and the command format is shown in Figure 7.3-1 and Figure 7.3-2.

Table 7.3-1. SPI slave controller interface

| Command field [7:0] | CMD default code | Data field length                                                                                                                                             | Description                                                                                                   |
|---------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------|
| Power Off (PWOFF)   | 8'h02            | 0 byte                                                                                                                                                        | Master uses this configure command so that the MCU turns off the SPI slave controller.                        |
| Power On (PWON)     | 8'h04            | 0 byte                                                                                                                                                        | Master uses this configure command to wakeup the system and tell the MCU to turn on the SPI slave controller. |
| Read Status (RS)    | 8'h06            | 1 byte (SPI slave feedback)                                                                                                                                   | Master reads Slave status register.                                                                           |
| Write Status (WS)   | 8'h08            | 1 byte                                                                                                                                                        | Master writes Slave status register to clean the error bit, such as write 1 to clear.                         |
| Config Read (CR)    | 8'h0a            | SIZE_OF_ADDR <ul style="list-style-type: none"> <li>• 1: 4 bytes address, 4 bytes data length.</li> <li>• 0: 2 bytes address, 2 bytes data length.</li> </ul> | Master configures the SPI Slave to read data.                                                                 |

| Command field [7:0] | CMD default code | Data field length                                                                                        | Description                                    |
|---------------------|------------------|----------------------------------------------------------------------------------------------------------|------------------------------------------------|
| Config Write (CW)   | 8'h0c            | SIZE_OF_ADDR<br>• 1: 4 bytes address, 4 bytes data length.<br>• 0: 2 bytes address, 2 bytes data length. | Master configures the SPI Slave to write data. |
| Read Data (RD)      | 8'h81            | N bytes. Burst data payload.                                                                             | Master reads data.                             |
| Write Data (WD)     | 8'h0e            | N bytes. Burst data payload.                                                                             | Master writes data.                            |
| Config Type (CT)    | 8'h10            | 1 byte:<br>• [7:3] Not used<br>• [2] SIZE_OF_ADDR<br>• [1:0] SPIS_TYPE                                   | Master configures the SPI Slave type.          |



Figure 7.3-1. SPI slave controller commands waveform



Figure 7.3-2. Config read/write (CR/CW) command format

### 7.3.1. SPI slave control flow

The SPI slave control flow is shown in Figure 7.3-3. First, the SPI master sends a “power on” command to turn on the SPI slave controller then transmits a “config read/write” command to configure the transfer data length and read/write address of the memory. After the SPI slave is configured, it can send/receive data package with SPI master by the “read/write data” command. Last, use the “power off” command to turn off the SPI slave controller. In each state, the SPI master transmits the “read status” command to poll SPI slave status. If the SPI master detects an error state flag bit, it should send a “write status” command to clear the bit and poll this bit until it turns low. The SPI master can transmit a “config type” command to configure data transmission type (Single, Dual, or Quad mode) according to user requirements. The SPI slave control flow is shown in Table 7.3-2.



Figure 7.3-3. SPI slave control flow diagram

Table 7.3-2. SPI slave status description (use RS command to poll SPI slave status)

| Function         | Bit | Usage (status[bit] = function)                                                                                                                                                                       |
|------------------|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SLV_ON           | 0   | Master polls this bit until slave is on after sending POWERON CMD or off after sending POWEROFF CMD.                                                                                                 |
| SR_CFG_SUCCESS   | 1   | Master checks this bit for the CW/CR command status.                                                                                                                                                 |
| SR_TXRX_FIFO_RDY | 2   | Set this bit when the slave is ready to send/receive data (master can send RD/WD command). Clean the bit after SPI slave receives a CR/CW command.                                                   |
| SR_RD_ERR        | 3   | After a read command, master can read this bit to check for an error in the read transfer. If there is an error, the master should send WS command to clear this bit and poll this bit until it's 0. |
| SR_WR_ERR        | 4   | After a WD command, master can read this bit to check for an error in the write transfer. If there is an error, the master should send WS command to clear this bit and poll this bit until it's 0.  |
| SR_RDWR_FINISH   | 5   | After RD/WD transaction, master can poll this bit to check if read/write transfer is finished. Clean the bit after the SPI slave receives a CR/CW command.                                           |
| SR_TIMEOUT_ERR   | 6   | Indicates the SPI slave didn't receive input signal for sometime when                                                                                                                                |

| Function   | Bit | Usage (status[bit] = function)                                                                                                                                          |
|------------|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |     | chip select signal was active. The SPI master should send a WS command to clear this bit and poll this bit until it's 0.                                                |
| SR_CMD_ERR | 7   | If master sends an error command in the first byte, master detects the error status through the received data. Clean it after the SPI slave receives a correct command. |

### 7.3.2. SPI slave modes

- SPI slave single mode.

The typical SPI transmission mode is single SPI, it's a 4-pin protocol. Set the register **SPIS\_TYPE** to 0 to enter single mode. The single mode data transmission diagrams are shown in Figure 7.3-4 and Figure 7.3-5.



Figure 7.3-4. SPI slave single mode write data



Figure 7.3-5. SPI slave single mode read data

- SPI slave dual mode.

The dual mode SPI is also a 4-pin protocol. Set the register **SPIS\_TYPE** to 1 to enter this mode. The dual mode data transmission diagrams are shown in Figure 7.3-6 and Figure 7.3-7.



Figure 7.3-6. SPI slave dual mode write data



Figure 7.3-7. SPI slave dual mode read data

3) SPI slave quad mode.

The quad mode SPI is a 6-pin protocol. Set the register **SPIS\_TYPE** to 2 to enter this mode. The quad mode transmission diagrams are shown in Figure 7.3-8 and Figure 7.3-9.



Figure 7.3-8. SPI slave quad mode write data



Figure 7.3-9. SPI slave quad mode read data

## 7.4. Register mapping

Module name: SPI\_SLAVE Base address: (+AooBooooh)

| Address   | Name                           | Width (bits) | Register Function                      |
|-----------|--------------------------------|--------------|----------------------------------------|
| AooBooo   | <b>SPISLV_CTRL</b>             | 32           | SPI Slave Control Register             |
| AooBooo4  | <b>SPISLV_TRIG</b>             | 32           | SPI Slave Trigger Register             |
| AooBooo8  | <b>SPISLV_IE</b>               | 32           | SPI Slave Interrupt Enable             |
| AooBoooC  | <b>SPISLV_INT</b>              | 32           | SPI Slave Interrupt                    |
| AooBooo10 | <b>SPISLV_STA</b>              | 32           | SPI Slave Status                       |
| AooBooo14 | <b>SPISLV_TRANS_LENGTH</b>     | 32           | SPI Slave Transfer Length Register     |
| AooBooo18 | <b>SPISLV_TRANS_ADDR</b>       | 32           | SPI Slave Transfer Address Register    |
| AooBooo1C | <b>SPISLV_TMOUT_THR</b>        | 32           | SPI Slave Timeout Threshold Register   |
| AooBooo20 | <b>SPISLV_BUFFER_BASE_ADDR</b> | 32           | SPI Slave Buffer Base Address Register |
| AooBooo24 | <b>SPISLV_BUFFER_SIZE</b>      | 32           | SPI Slave Buffer Size Register         |
| AooBooo28 | <b>SPISLV_CMD RECEIVED</b>     | 32           | SPI Slave CMD Received                 |
| AooBooo2C | <b>SPISLV_CMD_DEF0</b>         | 32           | SPI Slave Command Define 0             |
| AooBooo30 | <b>SPISLV_CMD_DEF1</b>         | 32           | SPI Slave Command Define 1             |
| AooBooo34 | <b>SPISLV_CMD_DEF2</b>         | 32           | SPI Slave Command Define 2             |

|          |                       |    |                                          |
|----------|-----------------------|----|------------------------------------------|
| AooBoo38 | <b>SPISLV_DLYSEL0</b> | 32 | <b>SPI Slave Delay Select 0 Register</b> |
| AooBoo3C | <b>SPISLV_DLYSEL1</b> | 32 | <b>SPI Slave Delay Select 1 Register</b> |
| AooBoo40 | <b>SPISLV_DLYSEL2</b> | 32 | <b>SPI Slave Delay Select 2 Register</b> |

| AooBoooo SPISLV_CTRL SPI Slave Control Register 00000100 |    |    |    |    |                       |    |                    |    |    |                   |    |    |    |    |    |                                    |
|----------------------------------------------------------|----|----|----|----|-----------------------|----|--------------------|----|----|-------------------|----|----|----|----|----|------------------------------------|
| Bit                                                      | 31 | 30 | 29 | 28 | 27                    | 26 | 25                 | 24 | 23 | 22                | 21 | 20 | 19 | 18 | 17 | 16                                 |
| <b>Name</b>                                              |    |    |    |    | <b>SPIS_DUMMY_CNT</b> |    |                    |    |    |                   |    |    |    |    |    | <b>SPI_S_MI_SO_E_AR_LY_T_RA_NS</b> |
| <b>Type</b>                                              |    |    |    |    | <b>RW</b>             |    |                    |    |    |                   |    |    |    |    |    | <b>RW</b>                          |
| <b>Reset</b>                                             |    |    |    |    | 0                     | 0  | 0                  | 0  |    |                   |    |    |    |    |    | 0                                  |
| <b>Bit</b>                                               | 15 | 14 | 13 | 12 | 11                    | 10 | 9                  | 8  | 7  | 6                 | 5  | 4  | 3  | 2  | 1  | 0                                  |
| <b>Name</b>                                              |    |    |    |    |                       |    | <b>SPIS_CTR_L1</b> |    |    | <b>SPIS_CTRL0</b> |    |    |    |    |    |                                    |
| <b>Type</b>                                              |    |    |    |    |                       |    | <b>RW</b>          |    |    | <b>RW</b>         |    |    |    |    |    |                                    |
| <b>Reset</b>                                             |    |    |    |    |                       |    | 0                  | 1  |    | 0                 | 0  | 0  | 0  | 0  | 0  | 0                                  |

| Bit(s) | Name                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27:24  | SPIS_DUMMY_CNT        | <b>Dummy count</b><br>The number of dummy bits in one packet. <ul style="list-style-type: none"> <li>• Dummy phase is the second transmission of packet between command phase and data phase.</li> <li>• Dummy phase cannot transmit/receive data, it's only used in dual or quad SPI modes (SPIS_TYPE is 1 or 2).</li> </ul>                                                                                                                                                                                                                                                                                                                                                          |
| 16     | SPIS_MISO_EARLY_TRANS | <b>Early transmit data</b><br>Defines whether to transmit data half SCK cycle early. It's used to improve the SPI timing.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 9:8    | SPIS_CTRL1            | <b>SPI slave general configuration setting 1</b> <ul style="list-style-type: none"> <li>• [1]: SPIS_DEC_ADDR_EN, indicates whether software decode address is sent by the SPI master. <ul style="list-style-type: none"> <li>◦ 0: software will not decode the address. The address of read/write memory is set by master configure read/write command.</li> <li>◦ 1: software will decode the address of read/write memory.</li> </ul> </li> <li>• [0]: SPIS_SW_RDY_EN, if the value is 1, defines whether hardware automatically sets the register SPIS_TXDMA_SW_RDY or SPIS_RXDMA_SW_RDY.</li> </ul>                                                                                |
| 6:0    | SPIS_CTRL0            | <b>SPI slave general configuration setting 0</b> <ul style="list-style-type: none"> <li>• [6]: SIZE_OF_ADDR, defines CW/CR command format, can be configured by master command or slave software settings. <ul style="list-style-type: none"> <li>◦ 0: Data filed includes 2 bytes of transfer address and 2 bytes of transfer length.</li> <li>◦ 1: Data filed includes 4 bytes of transfer address and 4 bytes of transfer length.</li> </ul> </li> <li>• [5:4]: SPIS_TYPE, indicates the SPI data transmission type, can be configured by master command or software settings. <ul style="list-style-type: none"> <li>◦ 0: Single SPI</li> <li>◦ 1: Dual SPI</li> </ul> </li> </ul> |

- 2: Quad SPI
- 3: Not used
- [3]: RXMSBF, indicates whether the first byte of the received RX data received is MSB. Set RXMSBF to 1 to define the first byte as MSB, otherwise set it to 0.
- [2]: TXMSBF, indicates the first byte of the transmitted TX data is MSB. Set TXMSBF to 1 to define the first byte as MSB, otherwise set it to 0.
- [1]: CPOL, control bit of the SCK polarity.
  - 0: CPOL = 0
  - 1: CPOL = 1
- [0]: CPHA, control bit of the SCK sample data phase
  - 0: CPHA = 0
  - 1: CPHA = 1

| AooB0004 <u>SPISLV_TRIG</u> |    | SPI Slave Trigger Register |    |    |    |    |    |                                   |    |    |    |    |    |    |    |                    | 00000000                              |  |  |  |
|-----------------------------|----|----------------------------|----|----|----|----|----|-----------------------------------|----|----|----|----|----|----|----|--------------------|---------------------------------------|--|--|--|
| Bit                         | 31 | 30                         | 29 | 28 | 27 | 26 | 25 | 24                                | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                 | SPI<br>S_T<br>XD<br>MA<br>S_W_RD<br>Y |  |  |  |
| Name                        |    |                            |    |    |    |    |    | SPI<br>S_RX<br>DM<br>A_SW<br>R_DY |    |    |    |    |    |    |    |                    |                                       |  |  |  |
| Type                        |    |                            |    |    |    |    |    | WO                                |    |    |    |    |    |    |    | WO                 |                                       |  |  |  |
| Reset                       |    |                            |    |    |    |    |    | 0                                 |    |    |    |    |    |    |    | 0                  |                                       |  |  |  |
| Bit                         | 15 | 14                         | 13 | 12 | 11 | 10 | 9  | 8                                 | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                  |                                       |  |  |  |
| Name                        |    |                            |    |    |    |    |    | SPI<br>S_S<br>W_RS<br>T           |    |    |    |    |    |    |    | SPI<br>S_S<br>W_ON |                                       |  |  |  |
| Type                        |    |                            |    |    |    |    |    | WO                                |    |    |    |    |    |    |    | WO                 |                                       |  |  |  |
| Reset                       |    |                            |    |    |    |    |    | 0                                 |    |    |    |    |    |    |    | 0                  |                                       |  |  |  |

| Bit(s) | Name              | Description                                                                                                                                                                                                                                                    |
|--------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24     | SPIS_RXDMA_SW_RDY | <b>Software ready to receive data</b><br>Write 1 to this bit to indicate the SPI slave can receive RX data. TXRX_FIFO_RDY of the status of STA register will be set. And master can query the status to check whether the slave is ready to receive data.      |
| 16     | SPIS_TXDMA_SW_RDY | <b>Software ready to transmit data</b><br>Write 1 to this bit to indicate the SPI slave can transmit TX data. TXRX_FIFO_RDY of STA register status will be set. And the master can query the status to check whether the slave is ready to transmit data.      |
| 8      | SPIS_SW_RST       | <b>Software reset</b><br>Software reset bit; resets the state machine and data FIFO of SPI slave controller (not the register define). When this bit is 1, software reset is active high, and hardware can automatically recover to 0. The default value is 0. |
| 0      | SPIS_SW_ON        | <b>Software ON</b><br>The SPI slave controller is enabled by software, the slave software can set SR_SLV_ON by SPIS_SW_ON control.                                                                                                                             |

| AooB0008 | <u>SPISLV_IE</u> | SPI Slave Interrupt Enable | 00000000 |
|----------|------------------|----------------------------|----------|
|----------|------------------|----------------------------|----------|

AooBooo8      **SPISLV IE**      SPI Slave Interrupt Enable      00000000

| <b>Bit</b>     | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Bit</b>     | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>SPIS IE</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| RW             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8:0           | SPIS IE     | <b>SPI slave interrupt source enable</b><br>[8]: TMOUT_ERR_IE, interrupt enable bit of timeout error<br>[7]: WR_DATA_ERR_IE, interrupt enable bit of SPI master write data error<br>[6]: RD_DATA_ERR_IE, interrupt enable bit of SPI master read data error<br>[5]: POWER_ON_IE, interrupt enable bit of SPI slave receive power-on command<br>[4]: POWER_OFF_IE, interrupt enable bit of SPI slave receive power-off<br>[3]: WR_TRANS_FINISH_IE, interrupt enable bit of SPI master write data finish<br>[2]: RD_TRANS_FINISH_IE, interrupt enable bit of SPI master read data finish<br>[1]: WR_CFG_FINISH_IE, interrupt enable bit of SPI master configure write finish<br>[0]: RD_CFG_FINISH_IE, interrupt enable bit of SPI master configure read finish |

AooBoooC      **SPISLV INT**      SPI Slave Interrupt      00000000

| <b>Bit</b>                                                                   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>                                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Bit</b>                                                                   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>                                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>SPIS INT</b>                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| RC                                                                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 0    0    0    0    0    0    0    0    0    0    0    0    0    0    0    0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8:0           | SPIS INT    | <b>SPI slave interrupt source</b><br>[8]: TMOUT_ERR_INT, timeout error interrupt<br>[7]: WR_DATA_ERR_INT, SPI master write data error interrupt<br>[6]: RD_DATA_ERR_INT, SPI master read data error interrupt<br>[5]: POWER_ON_INT, SPI slave receive power-on command interrupt<br>[4]: POWER_OFF_INT, SPI slave receive power-off command interrupt<br>[3]: WR_TRANS_FINISH_INT, SPI master write data finish interrupt<br>[2]: RD_TRANS_FINISH_INT, SPI master read data finish interrupt<br>[1]: WR_CFG_FINISH_INT, SPI master configure write finish interrupt<br>[0]: RD_CFG_FINISH_INT, SPI master configure read finish interrupt |

AooBooo10      **SPISLV STA**      SPI Slave Status      00000000

| <b>Bit</b>                                                                   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>                                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Bit</b>                                                                   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>                                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                                                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>SPIS STA</b>                                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| RO                                                                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 0    0    0    0    0    0    0    0    0    0    0    0    0    0    0    0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b> |
|---------------|-------------|--------------------|
| 9:0           | SPIS STA    |                    |

13:0 SPIS\_STA

**SPI slave status**

- SPIS\_STA[7:0] is the feedback data when SPI master send read status command
  - [13]: SR\_POWER\_ON  
SPI slave receives power-on command.  
Cleared after SPIS\_SW\_ON is set to 1.
  - [12]: SR\_POWER\_OFF  
SPI slave receives power-off command.  
Cleared after SPIS\_SW\_ON is set to 0.
  - [11]: SR\_WR\_FINISH  
SPI master write data finish.  
Cleared after the next configure write or read (CW/CR) command.
  - [10]: SR\_RD\_FINISH  
SPI master read data finish.  
Cleared after the next CW/CR command.
  - [9]: SR\_CFG\_WRITE\_FINISH  
SPI slave receive CW command is complete.  
Cleared after SR\_TXRX\_FIFO\_RDY = 1.
  - [8]: SR\_CFG\_READ\_FINISH  
SPI slave receive CR command is finished.  
Cleared after SR\_TXRX\_FIFO\_RDY = 1.
  - [7]: SR\_CMD\_ERROR  
Used for SPI master to debug,  
Cleared after SPI master sends a correct command.
  - [6]: SR\_TIMEOUT\_ERR
- SPI slave doesn't receive SCK signal for some time when chip select signal is active.  
If there is an error, master must send WS command to clear this bit and poll this bit until it's 0.
  - [5]: SR\_RDWR\_FINISH  
The bit is set to 1 when SPI slave receives or sends all data.  
Cleared after SPI slave receives CR/CW command.
  - [4]: SR\_WR\_ERR  
After a WR command, master can read this bit to check for an error in the write transfer through RS command.  
If there is an error, master must send WS command to clear this bit and poll this bit until it's 0.
  - [3]: SR\_RD\_ERR  
After an RD command, master can read this bit to check for an error in the read transfer through RS.  
If there is timeout error, master must send WS command to clear this bit and poll this bit until it's 0.
  - [2]: SR\_TXRX\_FIFO\_RDY  
When CR, this bit used to indicate whether TX FIFO is ready. Master polls this bit to know if the slave is ready to send data, then master can send the RD command.
- When CW, this bit used to indicate whether RX FIFO is ready. Master polls this bit to know if the slave is ready to send data, then master can send WD command.  
This bit will be cleared after SPI slave receives CR/CW command.
  - [1]: SR\_CFG\_SUCCESS  
SPI master configure package address/length successfully.
  - [0]: SR\_SLV\_ON
- SPI slave controller enable by set SPIS\_SW\_ON = 1. After SPI slave receive POWER-ON command, slave software can set this bit by control SPIS\_SW\_ON.

**AooBoo14 SPISLV TRAN S LENGTH** SPI Slave Transfer Length Register 00000000

| Bit                             | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|---------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>SPIS_TRANS_LENGTH[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| RO                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset                           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit                             | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>SPIS_TRANS_LENGTH[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| RO                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset                           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name              | Description                                                                        |
|--------|-------------------|------------------------------------------------------------------------------------|
| 31:0   | SPIS_TRANS_LENGTH | <b>Transfer length</b><br>Defines the SPI master transfer package length in bytes. |

**AooBoo18 SPISLV TRAN S ADDR** SPI Slave Transfer Address Register 00000000

| Bit                           | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>SPIS_TRANS_ADDR[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| RO                            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset                         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit                           | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>SPIS_TRANS_ADDR[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| RO                            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset                         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name            | Description                                                                       |
|--------|-----------------|-----------------------------------------------------------------------------------|
| 31:0   | SPIS_TRANS_ADDR | <b>Transfer address</b><br>Defines the SPI master transfer package start address. |

**AooBoo1C SPISLV TMOUT T THR** SPI Slave Timeout Threshold Register 000000FF

| Bit                          | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>SPIS_TMOUT_THR[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| RW                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset                        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit                          | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>SPIS_TMOUT_THR[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| RW                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset                        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  |

| Bit(s) | Name           | Description                                                                                                                                                                                                           |
|--------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | SPIS_TMOUT_THR | <b>Timeout threshold time</b><br>Timeout interrupt occurs if SPI slave doesn't receive SCK signal when the CS select signal is active and the period exceeds this threshold time. The timeout counter unit is 3.05μs. |

**AooBoo20 SPISLV BUFF ER BASE AD DR** SPI Slave Buffer Base Address Register 00000000

SPISLV\_BUFFAooBoo20 ER\_BASE\_AD SPI Slave Buffer Base Address Register 00000000

DR

| Bit   | 31                                  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|-------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | <b>SPIS_BUFFER_BASE_ADDR[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                                   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15                                  | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>SPIS_BUFFER_BASE_ADDR[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                                   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

Bit(s)NameDescription31:0 SPIS\_BUFFER\_BASE\_ADDR **Buffer base address**

Configurable DMA address to access memory.

SPISLV\_BUFFAooBoo24 ER\_SIZE SPI Slave Buffer Size Register 00000000

| Bit   | 31                             | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|--------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | <b>SPIS_BUFFER_SIZE[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW                             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                              | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15                             | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>SPIS_BUFFER_SIZE[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW                             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                              | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

Bit(s)NameDescription31:0 SPIS\_BUFFER\_SIZE **Buffer base size**

Configurable buffer size indicating whether SPI master is configured successfully.

SPISLV\_CMDAooBoo28 RECEIVED SPI Slave CMD Received 00000000

| Bit   | 31                       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|--------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  |                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15                       | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>SPIS_CMD_RECEIVED</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |                          |    |    |    |    |    |    |    |    |    |    | 0  | 0  | 0  | 0  | 0  |

Bit(s)NameDescription7:0 SPIS\_CMD\_RECEIVED **Command received**

SPI slave received a command.

| <u>SPISLV_CMD</u><br>AooBoo2C <u>DEF0</u> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | SPI Slave Command Define 0 | 08060402 |
|-------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|----------------------------|----------|
|-------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|----------------------------|----------|

|              |                      |    |    |    |    |    |    |    |                       |    |    |    |    |    |    |    |
|--------------|----------------------|----|----|----|----|----|----|----|-----------------------|----|----|----|----|----|----|----|
| <b>Bit</b>   | 31                   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23                    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b>  | <b>SPIS_CMD_WS</b>   |    |    |    |    |    |    |    | <b>SPIS_CMD_RS</b>    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW                   |    |    |    |    |    |    |    | RW                    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                    | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 0                     | 0  | 0  | 0  | 0  | 1  | 1  | 0  |
| <b>Bit</b>   | 15                   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7                     | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | <b>SPIS_CMD_PWON</b> |    |    |    |    |    |    |    | <b>SPIS_CMD_PWOFF</b> |    |    |    |    |    |    |    |
| <b>Type</b>  | RW                   |    |    |    |    |    |    |    | RW                    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                    | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 0                     | 0  | 0  | 0  | 0  | 1  | 0  | 0  |

| <b>Bit(s)</b> | <b>Name</b>    | <b>Description</b>                                              |
|---------------|----------------|-----------------------------------------------------------------|
| 31:24         | SPIS_CMD_WS    | Defines Write Status (WS) command value, default value is ox08. |
| 23:16         | SPIS_CMD_RS    | Defines Read Status (RS) command value, default value is ox06.  |
| 15:8          | SPIS_CMD_PWON  | Defines Power-ON (PWON) command value, default value is ox04.   |
| 7:0           | SPIS_CMD_PWOFF | Defines Power-OFF (PWOFF) command value, default value is ox02. |

| <u>SPISLV_CMD</u><br>AooBoo30 <u>DEF1</u> |                    |    |    |    |    |    |    |    |                    |    |    |    |    |    |    | SPI Slave Command Define 1 | 0E810CoA |
|-------------------------------------------|--------------------|----|----|----|----|----|----|----|--------------------|----|----|----|----|----|----|----------------------------|----------|
| <b>Bit</b>                                | 31                 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23                 | 22 | 21 | 20 | 19 | 18 | 17 | 16                         |          |
| <b>Name</b>                               | <b>SPIS_CMD_WR</b> |    |    |    |    |    |    |    | <b>SPIS_CMD_RD</b> |    |    |    |    |    |    |                            |          |
| <b>Type</b>                               | RW                 |    |    |    |    |    |    |    | RW                 |    |    |    |    |    |    |                            |          |
| <b>Reset</b>                              | 0                  | 0  | 0  | 0  | 1  | 1  | 1  | 0  | 1                  | 0  | 0  | 0  | 0  | 0  | 0  | 1                          |          |
| <b>Bit</b>                                | 15                 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7                  | 6  | 5  | 4  | 3  | 2  | 1  | 0                          |          |
| <b>Name</b>                               | <b>SPIS_CMD_CW</b> |    |    |    |    |    |    |    | <b>SPIS_CMD_CR</b> |    |    |    |    |    |    |                            |          |
| <b>Type</b>                               | RW                 |    |    |    |    |    |    |    | RW                 |    |    |    |    |    |    |                            |          |
| <b>Reset</b>                              | 0                  | 0  | 0  | 0  | 1  | 1  | 0  | 0  | 0                  | 0  | 0  | 0  | 0  | 1  | 0  | 0                          |          |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                                 |
|---------------|-------------|--------------------------------------------------------------------|
| 31:24         | SPIS_CMD_WR | Defines Write Data (WR) command value, default value is ox0e.      |
| 23:16         | SPIS_CMD_RD | Defines Read Data (RD) command value, default value is ox81.       |
| 15:8          | SPIS_CMD_CW | Defines Configure Write (CW) command value, default value is ox0c. |
| 7:0           | SPIS_CMD_CR | Defines Configure Read (CR) command value, default value is ox0a.  |

| <u>SPISLV_CMD</u><br>AooBoo34 <u>DEF2</u> |    |    |    |    |    |    |    |    |                    |    |    |    |    |    |    | SPI Slave Command Define 2 | 00000010 |
|-------------------------------------------|----|----|----|----|----|----|----|----|--------------------|----|----|----|----|----|----|----------------------------|----------|
| <b>Bit</b>                                | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23                 | 22 | 21 | 20 | 19 | 18 | 17 | 16                         |          |
| <b>Name</b>                               |    |    |    |    |    |    |    |    |                    |    |    |    |    |    |    |                            |          |
| <b>Type</b>                               |    |    |    |    |    |    |    |    |                    |    |    |    |    |    |    |                            |          |
| <b>Reset</b>                              |    |    |    |    |    |    |    |    |                    |    |    |    |    |    |    |                            |          |
| <b>Bit</b>                                | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7                  | 6  | 5  | 4  | 3  | 2  | 1  | 0                          |          |
| <b>Name</b>                               |    |    |    |    |    |    |    |    | <b>SPIS_CMD_CT</b> |    |    |    |    |    |    |                            |          |
| <b>Type</b>                               |    |    |    |    |    |    |    |    | RW                 |    |    |    |    |    |    |                            |          |
| <b>Reset</b>                              |    |    |    |    |    |    |    |    | 0                  | 0  | 0  | 1  | 0  | 0  | 0  | 0                          |          |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                                |
|---------------|-------------|-------------------------------------------------------------------|
| 7:0           | SPIS_CMD_CT | Defines Configure Type (CT) command value, default value is ox10. |

## 8. Inter-Integrated Circuit Controller

### 8.1. Overview

Inter-Integrated Circuit (I2C) is a two-wire serial interface. The two signals are SCL and SDA. SCL is a clock signal driven by the master. SDA is a bi-directional data signal that can be driven by either the master or the slave. This generic controller supports master role and conforms to the I2C specification.

### 8.2. Features

- I2C compliant master mode operation
- Adjustable clock speed for LS/FS mode operation
- Supports 7-bit/10-bit addressing
- Supports high-speed mode
- Supports slave clock extension under open-drain mode
- START/STOP/REPEATED START condition
- Polling/DMA Transfer Mode
- Multi-write per transfer (up to 65535 data bytes)
- Multi-read per transfer (up to 65535 data bytes)
- Multi-transfer per transaction (up to 65535 data bytes)
- Combined format transfer with length change capability
- Active drive/wired-and I/O configuration

### 8.3. Block diagram

The block diagram of the I2C is shown in Figure 8.3-1.



Figure 8.3-1. I2C block diagram

## 8.4. Functions

The controller is designed to be as generic as possible in order to support a wide range of devices for different combinations of transfer formats. Transfer format types supported through different software configurations are listed below:

Note: Terms used in the context of this document.

- Transfer. Any content encapsulated between a pair of Start, Stop and Repeated Start (RS).
- Transfer length. Number of bytes within the transfer.
- Transaction. A transaction contains multiple transfers and is sent after START register is set to 1.
- Transaction length. Number of transfers.



- 1) Single-byte access. In this case, TRANSAC\_LEN and TRANSFER\_LEN are both set to 1.



Figure 8.4-1. I2C single transfer single byte access

- 2) Multi-byte access. In this case, TRANSAC\_LEN is set to 1 and TRANSFER\_LEN is set to N. Overall multi-byte transfer is N bytes with an ACK.



**Figure 8.4-2. I2C single transfer multi byte access**

- 3) Multi-byte transfer and multi-transfer (same direction, either read or write). In this case, TRANSAC\_LEN is set to X and TRANSFER\_LEN is set to N.



**Figure 8.4-3. I2C multi transfer multi byte access**

- 4) Multi-byte transfer and multi-transfer with RS (same direction). If RS\_STOP is set to 1, the Stop then Start in the middle of transaction will be replaced by Repeated Start.



**Figure 8.4-4. I2C multi transfer multi byte access with RS**

- 5) Combined write or read with Repeated Start (direction change). In this case, TRANSAC\_LEN is set to 2, TRANSFER\_LEN is set to N and TRANSFER\_LEN\_AUX is set to M. If DIR\_CHANGE is 1, the SLAVE\_ADDR LSB will change from 0 to 1, which means write to read, after first transfer. Also the TRANSFER\_LEN\_AUX will be used after first transfer.

Note:

1. This format only supports write and then read sequence. Read and then write is not supported.
2. The transaction length in Figure 8.4-5 is 2.



**Figure 8.4-5. I2C multi transfer multi byte access with direction-change function**

## 8.5. Programming guide

### Common transfer programmable parameters

#### Programmable Parameters



**Figure 8.5-1. I2C transfer format programming guide**

After all the parameters above are set, set START register to 1. The START register will auto clear to 0 after transaction is over. To know when the transaction is over, one can poll the START register or disable INTR\_MASK and wait for interrupt.

### Output waveform timing programmable parameters



**Figure 8.5-2. I2C timing format programming guide**

## 8.6. Manual and DMA transfer modes for I2C controller

The controller offers two types of transfer modes, manual and DMA.

- When Manual mode is selected, in addition to the slave address register, the controller has a built-in 8 byte deep FIFO which allows the MCU to prepare up to 8 bytes of data for a write transfer or read up to 8 bytes of data for a read transfer.
- When DMA mode is enabled, the data to and from the FIFO is controlled by DMA transfer and can therefore support up to 65535 bytes of consecutive read or write, with the data is read from or written into another memory space. When DMA mode is enabled, the flow control mechanism is also implemented to hold the bus clock (SCL) when FIFO underflow or overflow condition is encountered.

Note: After enabling DMA\_EN register in I2C, starting data transfer isn't controlled by the START register in I2C, but by a register in DMA (PDMAx\_START). To avoid errors, it's suggested using SOFTRESET and FIFO\_ADDR\_CLR registers when PDMAx\_START is 0.

| DMA number | START register | Peripheral |
|------------|----------------|------------|
| DMA2       | PDMA2_START    | I2C0 TX    |
| DMA3       | PDMA3_START    | I2C0 RX    |
| DMA4       | PDMA4_START    | I2C1 TX    |
| DMA5       | PDMA5_START    | I2C1 RX    |

## 8.7. Register mapping

There are two I2C channels in this SOC.

| I2C number | Base address | Feature           | Source clock                                   |
|------------|--------------|-------------------|------------------------------------------------|
| I2C0       | 0xA0100000   | Supports DMA mode | Bus Clock (96MHz when CPU frequency is 192MHz) |

| I2C number | Base address | Feature           | Source clock                                   |
|------------|--------------|-------------------|------------------------------------------------|
| I2C1       | 0xA0110000   | Supports DMA mode | Bus Clock (96MHz when CPU frequency is 192MHz) |

**Module name: I2Co Base address: (+A0100000h)**

| Address  | Name                    | Width (bits) | Register Functionality                      |
|----------|-------------------------|--------------|---------------------------------------------|
| A0110000 | <u>DATA PORT</u>        | 32           | <b>Data port</b>                            |
| A0110004 | <u>SLAVE ADDR</u>       | 32           | <b>Slave address</b>                        |
| A0110008 | <u>INTR MASK</u>        | 32           | <b>Interrupt mask</b>                       |
| A011000C | <u>INTR STAT</u>        | 32           | <b>Interrupt status</b>                     |
| A0110010 | <u>CONTROL</u>          | 32           | <b>Control</b>                              |
| A0110014 | <u>CONTROL2</u>         | 32           | <b>Control2</b>                             |
| A0110020 | <u>TRANSFER LEN</u>     | 32           | <b>Number of bytes per transfer</b>         |
| A0110024 | <u>TRANSFER LEN AUX</u> | 32           | <b>Number of bytes per transfer</b>         |
| A0110028 | <u>TRANSAC LEN</u>      | 32           | <b>Number of transfers per transaction</b>  |
| A011002C | <u>DELAY LEN</u>        | 32           | <b>Inter delay length</b>                   |
| A0110030 | <u>TIMING</u>           | 32           | <b>Timing control register</b>              |
| A0110034 | <u>CLOCK DIV</u>        | 32           | <b>Clock divergence of I2C source clock</b> |
| A0110038 | <u>START</u>            | 32           | <b>Start the I2C transfer</b>               |
| A0110040 | <u>FIFO STAT</u>        | 32           | <b>FIFO status</b>                          |
| A0110048 | <u>FIFO ADDR CLR</u>    | 32           | <b>FIFO address clear</b>                   |
| A0110050 | <u>IO CONFIG</u>        | 32           | <b>IO configuration</b>                     |
| A0110060 | <u>HS</u>               | 32           | <b>High speed mode</b>                      |
| A0110070 | <u>SOFTRESET</u>        | 32           | <b>Soft Reset</b>                           |
| A0110074 | <u>DEBUGSTAT</u>        | 32           | <b>Debug status</b>                         |
| A0110078 | <u>DEBUGCTRL</u>        | 32           | <b>Debug control</b>                        |
| A0110080 | <u>ACKERR FLAG</u>      | 32           | <b>ACK error flag</b>                       |

| Ao100000 DATA PORT |    |    |    |    |    |    |    |    |    |           |    |    |    |    |    |    |
|--------------------|----|----|----|----|----|----|----|----|----|-----------|----|----|----|----|----|----|
| Data Port          |    |    |    |    |    |    |    |    |    |           |    |    |    |    |    |    |
| 00000000           |    |    |    |    |    |    |    |    |    |           |    |    |    |    |    |    |
| Bit                | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22        | 21 | 20 | 19 | 18 | 17 | 16 |
| Name               |    |    |    |    |    |    |    |    |    |           |    |    |    |    |    |    |
| Type               |    |    |    |    |    |    |    |    |    |           |    |    |    |    |    |    |
| Reset              |    |    |    |    |    |    |    |    |    |           |    |    |    |    |    |    |
| Bit                | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6         | 5  | 4  | 3  | 2  | 1  | 0  |
| Name               |    |    |    |    |    |    |    |    |    | DATA_PORT |    |    |    |    |    |    |
| Type               |    |    |    |    |    |    |    |    |    | RW        |    |    |    |    |    |    |
| Reset              |    |    |    |    |    |    |    |    |    | 0         | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name      | Description                                                     |
|--------|-----------|-----------------------------------------------------------------|
| 7:0    | DATA_PORT | FIFO access port. During master write sequence (slave_addr[0] = |

0), this port can be written by APB and during master read sequence (slave\_addr[0] = 1), this port can be read by APB.

Note, that slave\_addr must be set correctly before accessing the FIFO.

(DEBUG ONLY) If the fifo\_apb\_debug bit is set, then the FIFO can be read and written by the APB.

| <b>Ao100004 SLAVE_ADDR</b> |    |    |    |    |    |    |    |    |    |    |    |    |           |    | <b>Slave Address</b> | <b>000000BF</b> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----------------------------|----|----|----|----|----|----|----|----|----|----|----|----|-----------|----|----------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Bit</b>                 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19        | 18 | 17                   | 16              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>                |    |    |    |    |    |    |    |    |    |    |    |    |           |    |                      |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Rese t</b>              |    |    |    |    |    |    |    |    |    |    |    |    |           |    |                      |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Bit</b>                 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3         | 2  | 1                    | 0               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Name</b>                |    |    |    |    |    |    |    |    |    |    |    |    |           |    | <b>SLAVE_ADDR</b>    |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>                |    |    |    |    |    |    |    |    |    |    |    |    | <b>RW</b> |    |                      |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Rese t</b>              |    |    |    |    |    |    |    |    |    |    |    |    |           |    |                      |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                                                                                                                                              |
|---------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0           | SLAVE_ADDR  | This specifies the slave address of the device to be accessed. Bit 0 is defined by the I2C protocol to indicate the direction of transfer.<br>1: master read<br>0: master write |

| <b>Ao100008 INTR_MASK</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>Interrupt Mask</b>           | <b>00000000</b> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------------------|-----------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Bit</b>                | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17                              | 16              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Name</b>               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                 |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                 |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Rese t</b>             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                 |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Bit</b>                | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1                               | 0               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Name</b>               |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>MA SK _H S NA CK ER R</b>    |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>               |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>RW</b>                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Rese t</b>             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                 |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>MA SK _T RA NS AC C OM P</b> |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>RW</b>                       |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                 |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| <b>Bit(s)</b> | <b>Name</b>     | <b>Description</b>                                        |
|---------------|-----------------|-----------------------------------------------------------|
| 16            | MASK_HS_NACKERR | <b>Mask of HS Mode NACK error interrupt</b><br>0: disable |

---

|   |                   |                                                             |
|---|-------------------|-------------------------------------------------------------|
| 8 | MASK_ACKERR       | <b>Mask of ACK error interrupt</b><br>o: disable            |
| 0 | MASK_TRANSAC_COMP | <b>Mask of Transaction complete interrupt</b><br>o: disable |

---

| <b>Ao10000C INTR_STAT</b> |    |    |    |    |    |    |    |         |    |    |    |    |    |    | <b>Interrupt Status</b> |         |                                 |  | <b>oooooooooooo</b> |  |  |  |  |
|---------------------------|----|----|----|----|----|----|----|---------|----|----|----|----|----|----|-------------------------|---------|---------------------------------|--|---------------------|--|--|--|--|
| <b>Bit</b>                | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24      | 23 | 22 | 21 | 20 | 19 | 18 | 17                      | 16      | HS<br>_N<br>AC<br>KE<br>RR      |  |                     |  |  |  |  |
| <b>Name</b>               |    |    |    |    |    |    |    |         |    |    |    |    |    |    |                         | W1<br>C |                                 |  |                     |  |  |  |  |
| <b>Type</b>               |    |    |    |    |    |    |    |         |    |    |    |    |    |    |                         |         | o                               |  |                     |  |  |  |  |
| <b>Bit</b>                | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8       | 7  | 6  | 5  | 4  | 3  | 2  | 1                       | 0       | TR<br>AN<br>SA<br>C<br>CO<br>MP |  |                     |  |  |  |  |
| <b>Name</b>               |    |    |    |    |    |    |    | ACKERR  |    |    |    |    |    |    |                         |         | W1<br>C                         |  |                     |  |  |  |  |
| <b>Type</b>               |    |    |    |    |    |    |    | W1<br>C |    |    |    |    |    |    |                         |         | W1<br>C                         |  |                     |  |  |  |  |
| <b>Rese t</b>             |    |    |    |    |    |    |    | o       |    |    |    |    |    |    |                         |         | o                               |  |                     |  |  |  |  |

---

| <b>Bit(s)</b> | <b>Name</b>  | <b>Description</b>                                                                                                                             |
|---------------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| 16            | HS_NACKERR   | This status is asserted if the HS master code not acknowledged (NACK) error detection is enabled. If enabled, the transaction will be stopped. |
| 8             | ACKERR       | This status is asserted if ACK error detection is enabled. If enabled, the transaction will be stopped.                                        |
| 0             | TRANSAC_COMP | This status is asserted when a transaction is complete.                                                                                        |

---

| <b>Ao100010 CONTROL</b> |    |    |    |    |    |    |    |                                                        |    |    |    |    |    |    | <b>Control</b> |    |                           |  | <b>oooooooooooo</b> |  |  |  |  |
|-------------------------|----|----|----|----|----|----|----|--------------------------------------------------------|----|----|----|----|----|----|----------------|----|---------------------------|--|---------------------|--|--|--|--|
| <b>Bit</b>              | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24                                                     | 23 | 22 | 21 | 20 | 19 | 18 | 17             | 16 | DI<br>R<br>CH<br>AN<br>GE |  |                     |  |  |  |  |
| <b>Name</b>             |    |    |    |    |    |    |    | TR<br>AN<br>SF<br>ER<br>_L<br>EN<br>C<br>HA<br>NG<br>E |    |    |    |    |    |    |                | RW |                           |  |                     |  |  |  |  |
| <b>Type</b>             |    |    |    |    |    |    |    | RW                                                     |    |    |    |    |    |    |                |    | RW                        |  |                     |  |  |  |  |
| <b>Rese t</b>           |    |    |    |    |    |    |    | o                                                      |    |    |    |    |    |    |                |    | o                         |  |                     |  |  |  |  |
| <b>Bit</b>              | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8                                                      | 7  | 6  | 5  | 4  | 3  | 2  | 1              | 0  | RS<br>S<br>TO<br>P        |  |                     |  |  |  |  |
| <b>Name</b>             |    |    |    |    |    |    |    | DM<br>A<br>EN                                          |    |    |    |    |    |    |                |    | RW                        |  |                     |  |  |  |  |
| <b>Type</b>             |    |    |    |    |    |    |    | RW                                                     |    |    |    |    |    |    |                |    | RW                        |  |                     |  |  |  |  |
| <b>Rese t</b>           |    |    |    |    |    |    |    | o                                                      |    |    |    |    |    |    |                |    | o                         |  |                     |  |  |  |  |

---

| Bit(s) | Name                | Description                                                                                                                                                                                                                                                                                   |
|--------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24     | TRANSFER_LEN_CHANGE | This option specifies whether to change the transfer length after the first transfer is complete. If enabled, the transfers after the first transfer will use the TRANSFER_LEN_AUX parameter.<br>0: disable<br>1: enable                                                                      |
| 16     | DIR_CHANGE          | This option is used for combined transfer format, where the direction of transfer is to be changed from write to read after the FIRST RS condition. Note: when set to 1, the transfers after the direction change will be based on the TRANSFER_LEN_AUX parameter.<br>0: disable<br>1: enable |
| 8      | DMA_EN              | By default, it's disabled, and FIFO data shall be manually prepared by MCU. This setting is used for transfer sizes of less than 8 bytes and no multiple transfer is configured. When enabled, DMA requests are turned on, and the FIFO data is prepared in memory.<br>0: disable<br>1:enable |
| 0      | RS_STOP             | In LS/FS mode, this bit affects multi-transfer transaction only. It controls whether REPEATED-START condition is used between transfers. The last transfer always ends with a STOP.<br>In HS mode, this bit must be set to 1.<br>0: use STOP<br>1: use REPEATED-START                         |

| Ao100014 CONTROL2 |    |    |    |    |    |    |    |                                     |    |    |    |    |    |    | CONTROL2 |                                                  | 00000001 |  |  |  |  |
|-------------------|----|----|----|----|----|----|----|-------------------------------------|----|----|----|----|----|----|----------|--------------------------------------------------|----------|--|--|--|--|
| Bit               | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24                                  | 23 | 22 | 21 | 20 | 19 | 18 | 17       | 16                                               |          |  |  |  |  |
| Name              |    |    |    |    |    |    |    |                                     |    |    |    |    |    |    |          | CL<br>K<br>EX<br>T<br>EN                         |          |  |  |  |  |
| Type              |    |    |    |    |    |    |    |                                     |    |    |    |    |    |    |          | RW                                               |          |  |  |  |  |
| Reset             |    |    |    |    |    |    |    |                                     |    |    |    |    |    |    |          | 0                                                |          |  |  |  |  |
| Bit               | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8                                   | 7  | 6  | 5  | 4  | 3  | 2  | 1        | 0                                                |          |  |  |  |  |
| Name              |    |    |    |    |    |    |    | AC<br>KE<br>RR<br>D<br>ET<br>E<br>N |    |    |    |    |    |    |          | HS<br>_N<br>AC<br>KE<br>RR<br>_D<br>ET<br>E<br>N |          |  |  |  |  |
| Type              |    |    |    |    |    |    |    | RW                                  |    |    |    |    |    |    |          | RW                                               |          |  |  |  |  |
| Reset             |    |    |    |    |    |    |    | 0                                   |    |    |    |    |    |    |          | 1                                                |          |  |  |  |  |

| Bit(s) | Name       | Description                                                                                                                                                                                                                                                                                                    |
|--------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16     | CLK_EXT_EN | I2C specification allows slaves to hold the SCL line low if it's not yet ready for further processing. Therefore, if this bit is set to 1, master controller will enter a high wait state until the slave releases the SCL line. Note that this feature is only supported under open-drain mode.<br>0: disable |

---

|   |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |                   | 1: enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 8 | ACKERR_DET_EN     | This option enables slave acknowledgment error detection. When enabled, if slave acknowledge error is detected, the master terminates the transaction issuing a STOP condition and then asserts acknowledge error interrupt. The user software handles the error and then resets the FIFO address before reissuing transaction. If this option is disabled, the controller will ignore the slave ACK error and continue with the scheduled transaction.<br>0: disable<br>1: enable |
| 0 | HS_NACKERR_DET_EN | This enables NACKERR detection during the master code transmission. When enabled, if NACK is not received after master code has been transmitted, the transaction will terminate with a STOP condition.<br>0: disable<br>1: enable                                                                                                                                                                                                                                                 |

---

| <b>Ao100020 TRANSFER LEN</b> |                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>Number of Bytes per Transfer</b> |          |                     |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>00000001</b> |    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|------------------------------|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------------------------|----------|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|----|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Bit Name                     | 31                  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                                  | Bit Name | 31                  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17              | 16 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type                         |                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Type                                |          |                     |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Rese t                       |                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Rese t                              |          |                     |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Bit                          | 15                  | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                                   | Bit      | 15                  | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1               | 0  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name                         | <b>TRANSFER_LEN</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                     | Name     | <b>TRANSFER_LEN</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type                         | RW                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                     | Type     | RW                  |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Rese t                       | 0                   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1                                   | Rese t   | 0                   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0               | 1  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

---

| Bit(s) | Name         | Description                                                                                                                                                                    |
|--------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0   | TRANSFER_LEN | This indicates the number of data bytes to be transferred in 1 transfer unit (excluding slave address byte).<br>Note, no data will be transferred if the value is less than 1. |

---

| <b>Ao100024 TRANSFER LEN_AUX</b> |                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>*Number of Bytes per Transfer</b> |          |                         |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>00000001</b> |    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----------------------------------|-------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------------------------|----------|-------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|----|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Bit Name                         | 31                      | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                                   | Bit Name | 31                      | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17              | 16 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type                             |                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Type                                 |          |                         |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Rese t                           |                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Rese t                               |          |                         |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Bit                              | 15                      | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                                    | Bit      | 15                      | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1               | 0  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name                             | <b>TRANSFER_LEN_AUX</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                      | Name     | <b>TRANSFER_LEN_AUX</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type                             | RW                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                      | Type     | RW                      |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Rese t                           | 0                       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1                                    | Rese t   | 0                       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0               | 1  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

---

| Bit(s) | Name             | Description                                                                                                                                                                                                                                                       |
|--------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0   | TRANSFER_LEN_AUX | This field is valid only when DIR_CHANGE is set to 1. This indicates the number of data bytes to transfer in a single transfer unit (excluding slave address byte) for the transfers following the direction change. If DIR_CHANGE is 1, the first write transfer |

---

length depends on TRANSFER\_LEN, while the second read transfer length depends on TRANSFER\_LEN\_AUX. Direction change is always after the first transfer.

Note, no data will be transferred if the value is less than 1.

**Ao100028 TRANSAC LEN****Number of Transfers per Transaction****oooooooo0001**

| Bit Name    | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Type        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit         | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| TRANSAC_LEN |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Name        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t      | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  |

**Bit(s) Bit(s)****Name****Description**

15:0 TRANSAC\_LEN

This indicates the number of transfers in a single transaction.

Note, no data will be transferred if the value is less than 1.

**Ao10002C DELAY LEN****Inter Delay Length****oooooooo0002**

| Bit Name  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Type      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit       | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| DELAY_LEN |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Name      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t    |    |    |    |    |    |    |    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  |

**Bit(s) Bit(s)****Name****Description**

7:0 DELAY\_LEN

This sets the wait delay between consecutive transfers when RS\_STOP bit is set to 0 (the unit is the same as half pulse width).

**Ao100030 TIMING****Timing Control Register****00010303**

| Bit            | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t         |    |    |    |    |    |    |    | 0  |    |    |    |    |    |    |    |    |
| Bit            | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| SAMPLE_CNT_    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Name           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t         |    |    |    |    |    |    |    | 0  |    |    |    |    |    |    |    |    |
| Bit            | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| STEP_CNT_DIV   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Name           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t         |    |    |    |    |    |    |    | 0  |    |    |    |    |    |    |    |    |
| Bit            | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| DATA_READ_TIME |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

|        |  |  |  |  |  |     |   |   |  |  |   |   |   |   |
|--------|--|--|--|--|--|-----|---|---|--|--|---|---|---|---|
| e      |  |  |  |  |  | DIV |   |   |  |  |   |   |   |   |
| Type   |  |  |  |  |  | RW  |   |   |  |  |   |   |   |   |
| Rese t |  |  |  |  |  | 0   | 1 | 1 |  |  | 0 | 0 | 0 | 0 |

| Bit(s) | Name           | Description                                                                                                                                                                                                                                             |
|--------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24     | DATA_READ_ADJ  | When set to 1, data latch in sampling time during master reads are adjusted according to DATA_READ_TIME value. Otherwise, by default, data is latched at half of the high pulse width point.                                                            |
| 18:16  | DATA_READ_TIME | This value is valid only when DATA_READ_ADJ is set to 1. This can be used to adjust so that data is latched in at earlier sampling points (assuming data is settled by then) This value must be set to less than or equal to half the high pulse width. |
| 10:8   | SAMPLE_CNT_DIV | Used for LS/FS only. This adjusts the width of each sample.                                                                                                                                                                                             |
| 5:0    | STEP_CNT_DIV   | This specifies the number of samples per half pulse width (each high or low pulse).                                                                                                                                                                     |

| <b>Ao100034 CLOCK_DIV</b>                            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                  |   |   |
|------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------|---|---|
| <b>Clock Divergence of I2C Source Clock 00000004</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                  |   |   |
| Bit                                                  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16               |   |   |
| Type                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                  |   |   |
| Rese t                                               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                  |   |   |
| Bit                                                  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                |   |   |
| Name                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>CLOCK_DIV</b> |   |   |
| Type                                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>RW</b>        |   |   |
| Rese t                                               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 1                | 0 | 0 |

| Bit(s) | Name      | Description                                 |
|--------|-----------|---------------------------------------------|
| 2:0    | CLOCK_DIV | f_clock_div is equal to SCK / (CLOCK_DIV+1) |

| <b>Ao100038 START</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                |
|-----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------|
| <b>Start</b>          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                |
| Bit                   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16             |
| Type                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                |
| Rese t                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                |
| Bit                   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0              |
| Name                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>ST AR T</b> |
| Type                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>RW</b>      |
| Rese t                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0              |

| Bit(s) | Name  | Description                                                                                                     |
|--------|-------|-----------------------------------------------------------------------------------------------------------------|
| 0      | START | This register starts the transaction on the bus. It is automatically de-asserted at the end of the transaction. |

**Ao100040 FIFO\_STAT****FIFO Status****oooooooooooo**

| Bit Name | 31 | 30 | 29 | 28 | 27          | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19      | 18 | 17 | 16               |
|----------|----|----|----|----|-------------|----|----|----|----|----|----|----|---------|----|----|------------------|
| Type     |    |    |    |    | RD_ADDR     |    |    |    |    |    |    |    | WR_ADDR |    |    |                  |
| Reset    |    |    |    |    | 0           | 0  | 0  | 0  |    |    |    |    | 0       | 0  | 0  | 0                |
| Bit      | 15 | 14 | 13 | 12 | 11          | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3       | 2  | 1  | 0                |
| Name     |    |    |    |    | FIFO_OFFSET |    |    |    |    |    |    |    |         |    |    | WR_FULL_RD_EMPTY |
| Type     |    |    |    |    | RO          |    |    |    |    |    |    |    |         |    |    | RO               |
| Reset    |    |    |    |    | 0           | 0  | 0  | 0  |    |    |    |    |         |    |    | 0 1              |

**Bit(s) Name****Description**

27:24 RD\_ADDR  
The current read address pointer. (only bit [2:0] has physical meaning).

19:16 WR\_ADDR  
The current write address pointer. (only bit [2:0] has physical meaning).

11:8 FIFO\_OFFSET  
WR\_ADDR[3:0] - RD\_ADDR[3:0]

1:0 WR\_FULL\_RD\_EMPTY  
Bit 0 : FIFO is empty; Bit 1 : FIFO is full.

**Ao100048 FIFO\_ADDR\_CLR****FIFO Address Clear****oooooooooooo**

| Bit Name      | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Type          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit           | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| FIFO_ADDR_CLR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| WO            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 0             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**Bit(s) Name****Description**

0 FIFO\_ADDR\_CLR  
When written with a 1'b1, a 1 pulse FIFO\_ADDR\_CLR is generated to clear the FIFO address back to 0.

**Ao100050 IO\_CONFIG****IO Config****oooooooooooo**

| Bit Name       | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Type           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit            | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| IDLE           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| SDA_SCL_IO_CON |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Type      |  |  |  |  |  |  |  | OE<br>E<br>N |  |  |  |  |  |  |  |   | FIG |
|-----------|--|--|--|--|--|--|--|--------------|--|--|--|--|--|--|--|---|-----|
| Type      |  |  |  |  |  |  |  | RW           |  |  |  |  |  |  |  |   | RW  |
| Rese<br>t |  |  |  |  |  |  |  | 0            |  |  |  |  |  |  |  | 0 | 0   |

| Bit(s) | Name              | Description                                                                                                                                                                                   |
|--------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8      | IDLE_OE_EN        | In open-drain mode, this bit should be set to 0. In push-pull mode, this bit determines whether to drive bus in idle state.<br>0: don't drive bus in idle state<br>1: drive bus in idle state |
| 1:0    | SDA_SCL_IO_CONFIG | Bit 0 configures SCL IO; Bit 1 configures SDA IO<br>00: normal tri-state IO mode (push-pull mode)<br>11: open-drain mode                                                                      |

| Ao100060 HS |    |    |    |    |    |                       |    |    |    | High Speed Mode |    |    |    |                     |    |               |  | 00010000 |
|-------------|----|----|----|----|----|-----------------------|----|----|----|-----------------|----|----|----|---------------------|----|---------------|--|----------|
| Bit         | 31 | 30 | 29 | 28 | 27 | 26                    | 25 | 24 | 23 | 22              | 21 | 20 | 19 | 18                  | 17 | 16            |  |          |
| Name        |    |    |    |    |    | HS_SAMPLE_C<br>NT_DIV |    |    |    |                 |    |    |    | HS_STEP_CNT<br>_DIV |    |               |  |          |
| Type        |    |    |    |    |    | RW                    |    |    |    |                 |    |    |    | RW                  |    |               |  |          |
| Rese<br>t   |    |    |    |    |    | 0                     | 0  | 0  |    |                 |    |    |    | 0                   | 0  | 1             |  |          |
| Bit         | 15 | 14 | 13 | 12 | 11 | 10                    | 9  | 8  | 7  | 6               | 5  | 4  | 3  | 2                   | 1  | 0             |  |          |
| Name        |    |    |    |    |    | MASTER_CODE           |    |    |    |                 |    |    |    |                     |    | HS<br>_E<br>N |  |          |
| Type        |    |    |    |    |    | RW                    |    |    |    |                 |    |    |    |                     |    | RW            |  |          |
| Rese<br>t   |    |    |    |    |    | 0                     | 0  | 0  |    |                 |    |    |    |                     |    | 0             |  |          |

| Bit(s) | Name              | Description                                                                                                                                                                                                        |
|--------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 26:24  | HS_SAMPLE_CNT_DIV | Entering high-speed mode after the master code transfer is complete the sample width becomes dependent on this parameter.                                                                                          |
| 18:16  | HS_STEP_CNT_DIV   | Entering high-speed mode after the master code transfer is complete the number of samples per half pulse width becomes dependent on this value.                                                                    |
| 10:8   | MASTER_CODE       | This is a 3-bit programmable value to transmit the master code. When set to HS mode, the frequency of master code is defined by TIMING register and the frequency after the master code is defined by HS register. |
| 0      | HS_EN             | This enables the high-speed transaction. Note, set the RS_STOP to 1.                                                                                                                                               |

| Ao100070 SOFTRESET |    |    |    |    |    |    |    |    |    | Soft Reset |    |    |    |    |    |                |  | 00000000 |
|--------------------|----|----|----|----|----|----|----|----|----|------------|----|----|----|----|----|----------------|--|----------|
| Bit                | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22         | 21 | 20 | 19 | 18 | 17 | 16             |  |          |
| Name               |    |    |    |    |    |    |    |    |    |            |    |    |    |    |    |                |  |          |
| Type               |    |    |    |    |    |    |    |    |    |            |    |    |    |    |    |                |  |          |
| Rese<br>t          |    |    |    |    |    |    |    |    |    |            |    |    |    |    |    |                |  |          |
| Bit                | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6          | 5  | 4  | 3  | 2  | 1  | 0              |  |          |
| Name               |    |    |    |    |    |    |    |    |    |            |    |    |    |    |    | SO<br>FT<br>_R |  |          |

|           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |
|-----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|----------|
| Type      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | ES<br>ET |
| Rese<br>t |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | WO       |
|           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | o        |

| Bit(s) | Name       | Description                                                                                                              |
|--------|------------|--------------------------------------------------------------------------------------------------------------------------|
| 0      | SOFT_RESET | When written with a 1'b1, a 1 pulse soft reset is used as synchronous reset to reset the I2C internal hardware circuits. |

| <b>Ao100074 DEBUGSTAT</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>Debug Status</b>              |                     | <b>00000100</b> |           |   |    |   |   |
|---------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------------------------|---------------------|-----------------|-----------|---|----|---|---|
| Bit                       | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                               |                     |                 |           |   |    |   |   |
| Name                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | MA<br>ST<br>ER<br>_W<br>RIT<br>E |                     |                 |           |   |    |   |   |
| Type                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                  |                     |                 |           |   | RO |   |   |
| Rese<br>t                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                  |                     |                 |           |   | o  |   |   |
| Bit                       | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                                |                     |                 |           |   |    |   |   |
| Name                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | MA<br>ST<br>ER<br>_R<br>EA<br>D  | <b>MASTER_STATE</b> |                 |           |   |    |   |   |
| Type                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RO                               |                     |                 | <b>RO</b> |   |    |   |   |
| Rese<br>t                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 1                                |                     |                 |           | o | o  | o | o |

| Bit(s) | Name         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|--------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16     | MASTER_WRITE | <b>DEBUG ONLY:</b> 1 = current transfer is in the master write direction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 8      | MASTER_READ  | <b>DEBUG ONLY:</b> 1 = current transfer is in the master read direction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 4:0    | MASTER_STATE | <b>DEBUG ONLY:</b> reads back the current master_state.<br>o: idle state;<br>1: I2C master is preparing to send the start bit, SCL=1, SDA=1;<br>2: I2C master is sending out the start bit, SCL=1, SDA=o;<br>3: I2C master/slave is preparing to transmit the data bit, SCL=o, SDA=data bit (data bit can be changed when SCL=o);<br>4: I2C master/slave is transmitting data bit, SCL=1, SDA=data bit (data bit is stable when SCL=1);<br>5: I2C master/slave is preparing to transmit ACK bit, SCL=o, SDA=ACK (ACK bit can be changed when SCL=o);<br>6: I2C master/slave is transmitting the ACK bit, SCL=1, SDA=o (ACK bit is stable when SCL=1);<br>7: I2C master is preparing to send the stop bit or repeated-start bit, SCL=o, SDA=o/1 (o: stop bit; 1: repeated-start bit);<br>8: i2c master is sending out stop bit or repeated-start bit, SCL=1, SDA=1/o (1: stop bit; o: repeated-start bit);<br>9: I2C master is in delay start between two transfers, SCL=1, SDA=1;<br>10: I2C master is in FIFO wait state; for write transaction, it means |

FIFO is empty and the DMA controller needs to write data into FIFO; for read transaction, it means FIFO is full and I<sub>2</sub>C master is waiting for DMA controller to read data from FIFO, SCL=0, SDA=don't care;

12: I<sub>2</sub>C master is preparing to send data bits of master code. This state is used only in high-speed transaction, SCL=0, SDA=data bit of master code (data bit of master code can be changed when SCL=0);

13: I<sub>2</sub>C master is sending out data bit of master code. This state is used only in high-speed transaction, SCL=1, SDA=data bit of master code (data bit of master code is stable when SCL=1);

14: I<sub>2</sub>C master/slave is preparing to transmit NACK bit, SCL=0, SDA=NACK bit (NACK bit can be changed when SCL=0); This state is used only in high-speed transaction;

15: I<sub>2</sub>C master/slave is transmitting NACK bit, SCL=1, SDA=1; This state is used only in high-speed transaction.

### Ao100078 DEBUGCTRL

### Debug Control

### oooooooooo

| Bit Name | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24                             | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                |
|----------|----|----|----|----|----|----|----|--------------------------------|----|----|----|----|----|----|----|-------------------|
| Type     |    |    |    |    |    |    |    |                                |    |    |    |    |    |    |    |                   |
| Rese t   |    |    |    |    |    |    |    |                                |    |    |    |    |    |    |    |                   |
| Bit      | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8                              | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                 |
| Name     |    |    |    |    |    |    |    | AP<br>B<br>DE<br>BU<br>G<br>RD |    |    |    |    |    |    |    | FIFO_APB_DEBUG_RD |
| Type     |    |    |    |    |    |    |    | WO                             |    |    |    |    |    |    |    | RW                |
| Rese t   |    |    |    |    |    |    |    | 0                              |    |    |    |    |    |    |    | 0                 |

### Bit(s) Name

### Description

8 APB\_DEBUG\_RD

This bit is only valid when FIFO\_APB\_DEBUG is set to 1. Writing to this register will generate a single pulsed read signal for reading the FIFO data.

0 FIFO\_APB\_DEBUG

This is used for debug purposes. Use debugging tools to view the memory map. Turning this bit on will block the normal APB read access. APB read access to the FIFO is then enabled by writing to APB\_DEBUG\_RD.

0: disable

### Ao110080 ACKERR\_FLAG

### ACK Error Flag

### oooooooooo

| Bit Name | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Type     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit      | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name     |    |    |    |    |    |    |    |    |    |    |    |    |    | DA |    | DA |

|                   |  |  |  |  |  |  |  |  |  |  |  |  |                                                         |  |                                     |
|-------------------|--|--|--|--|--|--|--|--|--|--|--|--|---------------------------------------------------------|--|-------------------------------------|
| <b>e</b>          |  |  |  |  |  |  |  |  |  |  |  |  | <b>TA<br/>A<br/>CK<br/>ER<br/>R<br/>CL<br/>EA<br/>R</b> |  | <b>TA<br/>A<br/>CK<br/>ER<br/>R</b> |
| <b>Type</b>       |  |  |  |  |  |  |  |  |  |  |  |  | <b>RW</b>                                               |  | <b>RW</b>                           |
| <b>Rese<br/>t</b> |  |  |  |  |  |  |  |  |  |  |  |  | <b>o</b>                                                |  | <b>o</b>                            |

| <b>Bit(s)</b> | <b>Name</b>       | <b>Description</b>                                                                                                                                                                                                                                                     |
|---------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2             | DATA_ACKERR_CLEAR | Write 1 to clear data phase acknowledgment error (bit[0]). Must write back to 0 after clear.                                                                                                                                                                           |
| 0             | DATA_ACKERR       | After receiving ACK error interrupt (INTR_STAT[8]), check this bit to distinguish address phase ACK error from data phase ACK error<br>0: address phase ACK error<br>1: data phase ACK error. Note data phase ACK error cannot be detected during master receive mode. |

## 9. SD/SDIO Card Controller

---

### 9.1. Overview

The chipset hosts a mass storage device class (MSDC) — a USB computer peripheral connection protocol supporting removable disk storage and an SD card controller.

- 1) SD memory card specification version 2.0
- 2) SDIO card specification version 2.0.

The controller can be configured as a host for the SD/SDIO card.

### 9.2. Features

The main features of the controller:

- 32-bit access for control registers
- 8, 16, 32-bit access for FIFO in PIO mode
- Built-in CRC circuit
- Supports PIO mode, basic DMA mode, descriptor DMA mode for SD/SDIO
- Interrupt capabilities
- Data rate of up to 48Mbps in 1-bit mode, 48 x 4 Mbps in 4-bit mode, the module is targeted at 48MHz operating clock
- Programmable serial clock rate on SD bus (256 gears)
- Card detection capabilities: MT7682 uses the EINT controller for card detection
- Does not support SPI mode for SD memory card
- Does not support suspend or resume for SD memory Card

### 9.3. Block diagram

Figure 9.3-1 shows the MSDC block diagram.



Figure 9.3-1. MSDC block diagram

### 9.4. Functions

#### 9.4.1. Pin assignment

Table 9.4-1 presents the pins required for the SD memory card. Each pin corresponds to one IO pad. Note, that all IO pads have embedded pull-up and pull-down resistors as they are shared by the SD memory card. The resistors are controlled by the MSDC top register. The pull-down resistors for these pins can be used to save power.

Table 9.4-1. Sharing of pins for SD memory card controller

| No. | Name       | Type   | SD   | Description         |
|-----|------------|--------|------|---------------------|
| 1   | MA_MC0_CK  | O      | CLK  | Clock               |
| 2   | MA_MC0_DA0 | I/O/PP | DAT0 | Data line bit 0     |
| 3   | MA_MC0_DA1 | I/O/PP | DAT1 | Data line bit 1     |
| 4   | MA_MC0_DA2 | I/O/PP | DAT2 | Data line bit 2     |
| 5   | MA_MC0_DA3 | I/O/PP | DAT3 | Data line bit 3     |
| 6   | MA_MC0_CM0 | I/O/PP | CMD  | Command / Bus State |

## 9.5. Programming sequence

### 9.5.1. MSDC recommended command sequence

- 1) SD command without response.
  - Check, if SDC\_STA.SDCBUSY is 0 before issuing this command.
  - Check the status for MSDC\_INT.SD\_CMDRDY, MSDC\_INT.SD\_CMDTO and MSDC\_INT.SD\_RESP\_CRCERR bits.
- 2) SD command with response or R1B.
  - Check, if SDC\_STA.SDCBUSY is 0 before issuing this command.
  - Check the status for MSDC\_INT.SD\_CMDRDY, MSDC\_INT.SD\_CMDTO and MSDC\_INT.SD\_RESP\_CRCERR bits.
  - The response can be found in SDC\_RESP0 to SDC\_RESP3.
- 3) SD command with data read/write transfer.
  - Check, if SDC\_STA.SDCBUSY is 0 before issuing this command.
  - Check MSDC\_INT.SD\_CMDRDY/SD\_CMDTO/SD\_RESP\_CRCERR bits for command phase status.
  - The response can be found in SDC\_RESP0 to SDC\_RESP3.
  - Enable DMA, if needed (DMA\_CTRL register should be programmed).
 

Note, that DMA\_CTRL register should be programmed after command register is programmed.
  - PIO mode can also be used to move data (MSDC\_FIFOCS, MSDC\_RXDAT, MSDC\_TXDAT registers).
  - PIO mode and DMA mode cannot be switched during transfer or the result will be unexpected.
  - Check MSDC\_INT.SD\_XFER\_COMPLETE/ DMA\_DONE/ SD\_DATTO/ SD\_DATA\_CRCERR for data phase status.
- 4) For SD, software can choose to always check the status of SDC\_STA.SDCBUSY before issuing a new command. SDC\_STA\_CMDBUSY represents the command status.

## 9.6. Register mapping

There is one MSDC IP in this SoC.

*Table 9.6-1. MSDC register definition*

| MSDC number | Base address | Feature       |
|-------------|--------------|---------------|
| MSDC0       | 0xA1030000   | SD2.0/SDIO2.0 |

**Module name: MSDC0 Base address: (+A1030000h)**

| Address  | Name               | Width | Register Function                            |
|----------|--------------------|-------|----------------------------------------------|
| A1030000 | <b>MSDC_CFG</b>    | 32    | <b>MSDC Configuration Register</b>           |
| A1030004 | <b>MSDC_IOCON</b>  | 32    | <b>MSDC IO Configuration Register</b>        |
| A1030008 | <b>MSDC_PS</b>     | 32    | <b>MSDC Pin Status Register</b>              |
| A103000C | <b>MSDC_INT</b>    | 32    | <b>MSDC Interrupt Register</b>               |
| A1030010 | <b>MSDC_INEN</b>   | 32    | <b>MSDC Interrupt Enable Register</b>        |
| A1030014 | <b>MSDC_FIFOCS</b> | 32    | <b>MSDC FIFO Control and Status Register</b> |

| Address  | Name                  | Width | Register Function                      |
|----------|-----------------------|-------|----------------------------------------|
| A1030018 | <u>MSDC TXDATA</u>    | 32    | MSDC TX Data Port Register             |
| A103001C | <u>MSDC RXDATA</u>    | 32    | MSDC RX Data Port Register             |
| A1030030 | <u>SDC CFG</u>        | 32    | SD Configuration Register              |
| A1030034 | <u>SDC CMD</u>        | 32    | SD Command Register                    |
| A1030038 | <u>SDC ARG</u>        | 32    | SD Argument Register                   |
| A103003C | <u>SDC STS</u>        | 32    | SD Status Register                     |
| A1030040 | <u>SDC RESPo</u>      | 32    | SD Response Register 0                 |
| A1030044 | <u>SDC RESP1</u>      | 32    | SD Response Register 1                 |
| A1030048 | <u>SDC RESP2</u>      | 32    | SD Response Register 2                 |
| A103004C | <u>SDC RESP3</u>      | 32    | SD Response Register 3                 |
| A1030050 | <u>SDC BLK NUM</u>    | 32    | SD Block Number Register               |
| A1030058 | <u>SDC CSTS</u>       | 32    | SD Card Status Register                |
| A103005C | <u>SDC CSTS EN</u>    | 32    | SD Card Status Enable Register         |
| A1030060 | <u>SDC DATCRC STS</u> | 32    | SD Card Data CRC Status Register       |
| A1030080 | <u>SD ACMD RESP</u>   | 32    | SD ACMD Response Register              |
| A1030090 | <u>DMA SA</u>         | 32    | DMA Start Address Register             |
| A1030094 | <u>DMA CA</u>         | 32    | DMA Current Address Register           |
| A1030098 | <u>DMA CTRL</u>       | 32    | DMA Control Register                   |
| A103009C | <u>DMA CFG</u>        | 32    | DMA Configuration Register             |
| A10300A0 | <u>SW DBG SEL</u>     | 32    | MSDC Software Debug Selection Register |
| A10300A4 | <u>SW DBG OUT</u>     | 32    | MSDC Software Debug Output Register    |
| A10300A8 | <u>DMA LENGTH</u>     | 32    | DMA Length Register                    |
| A10300B0 | <u>PATCH BITo</u>     | 32    | MSDC Patch Bit Register 0              |
| A10300B4 | <u>PATCH BIT1</u>     | 32    | MSDC Patch Bit Register 1              |
| A10300EC | <u>PAD TUNE</u>       | 32    | MSDC Pad Tuning Register               |
| A10300Fo | <u>DAT RD DLYo</u>    | 32    | MSDC Data Delay Line Register 0        |
| A10300F4 | <u>DAT RD DLY1</u>    | 32    | MSDC Data Delay Line Register 1        |
| A10300F8 | <u>HW DBG SEL</u>     | 32    | MSDC Hardware Debug Selection Register |
| A1030100 | <u>MAIN VER</u>       | 32    | MSDC Main Version Register             |
| A1030104 | <u>ECO VER</u>        | 32    | MSDC ECO Version Register              |

A1030000 MSDC CFG MSDC Configuration Register 00000099

| Bit   | 31          | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23              | 22 | 21             | 20        | 19  | 18            | 17    | 16            |
|-------|-------------|----|----|----|----|----|----|----|-----------------|----|----------------|-----------|-----|---------------|-------|---------------|
| Name  |             |    |    |    |    |    |    |    |                 |    |                |           |     |               |       | CARD CK MOD E |
| Type  |             |    |    |    |    |    |    |    |                 |    |                |           |     |               |       | RW            |
| Reset |             |    |    |    |    |    |    |    |                 |    |                |           |     |               |       | 0             |
| Bit   | 15          | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7               | 6  | 5              | 4         | 3   | 2             | 1     | 0             |
| Name  | CARD_CK_DIV |    |    |    |    |    |    |    | CARD CK STAB LE |    | CARD CK DRV EN | PIO MOD E | RST | CARD CK PWD N | MSD C |               |
| Type  | RW          |    |    |    |    |    |    |    | RU              |    | RW             | RW        | Ao  | RW            | RW    |               |
| Reset | 0           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1               |    | 1              | 1         | 0   | 0             | 1     |               |

| Bit(s) | Mnemonic | Name           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------|----------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16     | CCKMD    | CARD_CK_MODE   | <b>MS/SD card clock mode</b><br>1'bo: Use clock divider output where msdc_ck is divided by msdc_src_ck and program the bits bit[15]~bit[8].<br>1'b1: Use msdc_src_ck as msdc_ck, bit[15]~bit[8] is ignored.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 15:8   | CCKDIV   | CARD_CK_DIV    | <b>MS/SD card clock divider</b><br>The register field controls clock frequency of serial clock on MS/SD bus. In non-DDR mode, msdc_ck equals SD bus clock. For example, for SDR25 or HS, msdc_ck and SD bus clock will be the same at 50MHz. In DDR mode, msdc_ck is twice the SD bus clock. For example, for DDR50, msdc_ck should be set to 100MHz and bus clock will be 50MHz.<br>8'oooooooooooo: msdc_ck =(1/2) * msdc_src_ck<br>8'oooooooooo1: msdc_ck = (1/(4*1)) * msdc_src_ck<br>8'oooooooo10: msdc_ck = (1/(4*2)) * msdc_src_ck<br>8'oooooooo11: msdc_ck = (1/(4*3))* msdc_src_ck<br>8'b00010000: msdc_ck = (1/(4*16))* msdc_src_ck<br>8'b11111111: msdc_ck = (1/(4*255)) * msdc_src_ck |
| 7      | CCKSB    | CARD_CK_STABLE | <b>MS/SD card clock stability</b><br>After programming the CARD_CK_MODE or CARD_CK_DIV, this bit will immediately go to "0" and return to "1", if the clock output is stable. User should poll this register to ensure the safety control of MSDC.<br>1'bo: Clock output is not stable<br>1'b1: Clock output is stable                                                                                                                                                                                                                                                                                                                                                                           |
| 4      | CCKDRVE  | CARD_CK_DRV_EN | <b>SD/MS Card Bus Clock drive enable bit</b><br>Set this bit to 1 to enable MSDC bus clock driver.<br>The default bus state depends on MSDC_CFG[1] CARD_CK_PWDN bit.<br>If MSDC_CFG[1] CARD_CK_PWDN= 1, the default clock is in freerun state.<br>If MSDC_CFG[1] CARD_CK_PWDN = 0, the default clock state is gated to 0.<br>Set this bit to 0 to put the bus state into tri-state.<br>Default is 1.<br>1'bo: Set the clock pad into tri-state.<br>1'b1: Enable MSDC to drive the clock pad, the state of CLK depends on MSDC_CFG[1] CARD_CK_PWDN                                                                                                                                                |
| 3      | PIO      | PIO_MODE       | <b>MS/SD PIO mode</b><br>PIO mode selection. Default is in PIO mode.<br>1'bo: DMA mode<br>1'b1: PIO mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 2      | RST      | RST            | <b>Software reset</b><br>Writing 1 to this register will cause internal synchronous reset of MS/SD controller, and it will not reset register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

1

**CCKPD**

CARD\_CK\_PWDN

settings and DMA controller.

The controller resets when this bit is 0. Software should wait for this bit to return to 0 after writing 1.

1'b0: MS/SD controller is not in reset state

1'b1: MS/SD controller is in reset state

**MSDC bus clock power down mode**

This bit controls the card clock power down mode.

1'b0: Clock is gated to 0, if no command or data is transmitted.

1'b1: Clock is in freerun state even if no command or data is transmitted. The clock may still be stopped when MSDC write data is not enough or there is no space for next read data.

0

**MSDC**

MSDC

**MS/SD mode selection**

The register bit is used to configure the controller as the host of a removable storage device or as the host of SD/MMC memory card. The default value is to configure the controller as the host of a removable storage device.

1'b0: Configure the controller as the host of removable storage device.

1'b1: Configure the controller as the host of SD/MMC memory card

**A1030004 MSDC IOCON****MSDC IO Configuration Register**

00000000

| Bit   | 31 | 30 | 29        | 28        | 27       | 26        | 25       | 24       | 23       | 22       | 21           | 20       | 19             | 18       | 17       | 16              |
|-------|----|----|-----------|-----------|----------|-----------|----------|----------|----------|----------|--------------|----------|----------------|----------|----------|-----------------|
| Name  |    |    |           |           |          |           |          | R_D7_SMP | R_D6_SMP | R_D5_SMP | R_D4_SMP     | R_D3_SMP | R_D2_SMP       | R_D1_SMP | R_D0_SMP |                 |
| Type  |    |    |           |           |          |           |          | L        | L        | L        | L            | L        | L              | L        | L        |                 |
| Reset |    |    |           |           |          |           |          | 0        | 0        | 0        | 0            | 0        | 0              | 0        | 0        |                 |
| Bit   | 15 | 14 | 13        | 12        | 11       | 10        | 9        | 8        | 7        | 6        | 5            | 4        | 3              | 2        | 1        | 0               |
| Name  |    |    | W_D3_SMPL | W_D2_SMPL | W_D1_SMP | W_D0_SMPL | W_D_L_SE | W_D_L    |          |          | R_D_SMPL_SEL |          | D_DL_YLIN_E_SE | R_D_SMPL | R_SM_PL  | SDR1_04_C_LKSEL |
| Type  |    |    | RW        | RW        | RW       | RW        | RW       | RW       |          |          | RW           |          | RW             | RW       | RW       | RW              |
| Reset |    |    | 0         | 0         | 0        | 0         | 0        | 0        |          |          | 0            |          | 0              | 0        | 0        | 0               |

| Bit(s) | Mnemonic      | Name      | Description                                                                                                                                                                                             |
|--------|---------------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23     | <b>RD7SPL</b> | R_D7_SMPL | <b>Read data 7 sample selection</b><br>This bit is only valid when bit 5 is ON<br>1'b0: Sample read data by external bus clock rising edge<br>1'b1: Sample read data by external bus clock falling edge |
| 22     | <b>RD6SPL</b> | R_D6_SMPL | <b>Read data 6 sample selection</b><br>This bit is only valid when bit 5 is ON<br>1'b0: Sample read data by external bus clock rising edge                                                              |

|    |               |           |                                                                                                                                                                                                                      |
|----|---------------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    |               |           | 1'b1: Sample read data by external bus clock falling edge                                                                                                                                                            |
| 21 | <b>RD5SPL</b> | R_D5_SMPL | <b>Read data 5 sample selection</b><br>This bit is only valid when bit 5 is ON<br>1'bo: Sample read data by external bus clock rising edge<br>1'b1: Sample read data by external bus clock falling edge              |
| 20 | <b>RD4SPL</b> | R_D4_SMPL | <b>Read data 4 sample selection</b><br>This bit is only valid when bit 5 is ON<br>1'bo: Sample read data by external bus clock rising edge<br>1'b1: Sample read data by external bus clock falling edge              |
| 19 | <b>RD3SPL</b> | R_D3_SMPL | <b>Read data 3 sample selection</b><br>This bit is only valid when bit 5 is ON<br>1'bo: Sample read data by external bus clock rising edge<br>1'b1: Sample read data by external bus clock falling edge              |
| 18 | <b>RD2SPL</b> | R_D2_SMPL | <b>Read data 2 sample selection</b><br>This bit is only valid when bit 5 is ON<br>1'bo: Sample read data by external bus clock rising edge<br>1'b1: Sample read data by external bus clock falling edge              |
| 17 | <b>RD1SPL</b> | R_D1_SMPL | <b>Read data 1 sample selection</b><br>This bit is only valid when bit 5 is ON<br>1'bo: Sample read data by external bus clock rising edge<br>1'b1: Sample read data by external bus clock falling edge              |
| 16 | <b>RDoSPL</b> | R_Do_SMPL | <b>Read data o sample selection</b><br>This bit is only valid when bit 5 is ON<br>1'bo: Sample read data by external bus clock rising edge<br>1'b1: Sample read data by external bus clock falling edge              |
| 13 | <b>WD3SPL</b> | W_D3_SMPL | <b>SDIO interrupt sample selection</b><br>This bit is only valid when bit 9 is ON<br>1'bo: Sample SDIO interrupt by external bus clock rising edge<br>1'b1: Sample SDIO interrupt by external bus clock falling edge |
| 12 | <b>WD2SPL</b> | W_D2_SMPL | <b>SDIO interrupt sample selection</b><br>This bit is only valid when bit 9 is ON<br>1'bo: Sample SDIO interrupt by external bus clock                                                                               |

|    |                 |              |                                                                                |
|----|-----------------|--------------|--------------------------------------------------------------------------------|
|    |                 |              | rising edge                                                                    |
| 11 | <b>WD1SPL</b>   | W_D1_SMPL    | 1'b1: Sample SDIO interrupt by external bus clock falling edge                 |
|    |                 |              | <b>SDIO interrupt sample selection</b>                                         |
|    |                 |              | This bit is only valid when bit 9 is ON                                        |
| 10 | <b>WDoSPL</b>   | W_Do_SMPL    | 1'bo: Sample SDIO interrupt by external bus clock rising edge                  |
|    |                 |              | 1'b1: Sample SDIO interrupt by external bus clock falling edge                 |
|    |                 |              | <b>CRC Status and SDIO interrupt sample selection</b>                          |
|    |                 |              | This bit is only valid when bit 9 is ON                                        |
| 9  | <b>WDSPLSEL</b> | W_D_SMPL_SEL | 1'bo: Sample CRC Status and SDIO interrupt by external bus clock rising edge   |
|    |                 |              | 1'b1: Sample CRC Status and SDIO interrupt by external bus clock falling edge  |
|    |                 |              | <b>Data line rising/falling latch fine tune selection in write transaction</b> |
|    |                 |              | 1'bo: All data lines share the same value indicated by MSDC_IOCON.W_D_SMPL     |
| 8  | <b>WDSPL</b>    | W_D_SMPL     | 1'b1: Each data line has its own selection value indicated by                  |
|    |                 |              | Data line 0: MSDC_IOCON.W_Do_SMPL                                              |
|    |                 |              | Data line 1: MSDC_IOCON.W_D1_SMPL                                              |
|    |                 |              | Data line 2: MSDC_IOCON.W_D2_SMPL                                              |
|    |                 |              | Data line 3: MSDC_IOCON.W_D3_SMPL                                              |
|    |                 |              | <b>CRC Status and SDIO interrupt sample selection</b>                          |
|    |                 |              | 1'bo: Sample CRC status and SDIO interrupt by external bus clock rising edge   |
|    |                 |              | 1'b1: Sample CRC status and SDIO interrupt by external bus clock falling edge  |
| 5  | <b>RDSPLSEL</b> | R_D_SMPL_SEL | <b>Data line rising/falling latch fine tune selection in read transaction</b>  |
|    |                 |              | 1'bo: All data lines share the same value indicated by MSDC_IOCON.R_D_SMPL     |
|    |                 |              | 1'b1: Each data line has its own selection value indicated by                  |
|    |                 |              | Data line 0: MSDC_IOCON.R_Do_SMPL                                              |
|    |                 |              | Data line 1: MSDC_IOCON.R_D1_SMPL                                              |
|    |                 |              | Data line 2: MSDC_IOCON.R_D2_SMPL                                              |
|    |                 |              | Data line 3: MSDC_IOCON.R_D3_SMPL                                              |
|    |                 |              | Data line 4: MSDC_IOCON.R_D4_SMPL                                              |
|    |                 |              | Data line 5: MSDC_IOCON.R_D5_SMPL                                              |
|    |                 |              | Data line 6: MSDC_IOCON.R_D6_SMPL                                              |
|    |                 |              | Data line 7: MSDC_IOCON.R_D7_SMPL                                              |

|   |                  |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---|------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3 | <b>DDLSEL</b>    | D_DLYLINE_SEL  | <b>Data line delay line fine tune selection</b><br>1'b0: All data lines share the same delay selection value indicated by PAD_TUNE.PAD_DAT_RD_RXDLY<br>1'b1: Each data line has its own delay selection value indicated by<br>Data line 0: DAT_RD_DLY0.DAT0_RD_DLY<br>Data line 1: DAT_RD_DLY0.DAT1_RD_DLY<br>Data line 2: DAT_RD_DLY0.DAT2_RD_DLY<br>Data line 3: DAT_RD_DLY0.DAT3_RD_DLY<br>Data line 4: DAT_RD_DLY1.DAT4_RD_DLY<br>Data line 5: DAT_RD_DLY1.DAT5_RD_DLY<br>Data line 6: DAT_RD_DLY1.DAT6_RD_DLY<br>Data line 7: DAT_RD_DLY1.DAT7_RD_DLY |
| 2 | <b>RDSPL</b>     | R_D_SMPL       | <b>Read data sample selection</b><br>1'b0: Sample read data by external bus clock rising edge<br>1'b1: Sample read data by external bus clock falling edge                                                                                                                                                                                                                                                                                                                                                                                                 |
| 1 | <b>RSPL</b>      | R_SMPL         | <b>Command response sample selection</b><br>1'b0: Sample response by external bus clock rising edge<br>1'b1: Sample response by external bus clock falling edge                                                                                                                                                                                                                                                                                                                                                                                            |
| 0 | <b>SDR104CKS</b> | SDR104_CLK_SEL | <b>SDR104 SCLK output clock control</b><br>This bit is only used when MSDC_CFG[17:16] CARD_CK_MODE is 2'b01.<br>1'b0: Bus clock output equals inverted msdc_src_ck<br>1'b1: Bus clock output equals msdc_src_ck                                                                                                                                                                                                                                                                                                                                            |

| <b>A1030008 MSDC PS</b> |            |    |    |    |    |    |    |     |     |    |    |    |    |    |    | <b>MSDC Pin Status Register</b> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>810F0002</b> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|------------|----|----|----|----|----|----|-----|-----|----|----|----|----|----|----|---------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-----------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>Bit</b>              | 31         | 30 | 29 | 28 | 27 | 26 | 25 | 24  | 23  | 22 | 21 | 20 | 19 | 18 | 17 | 16                              |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Name</b>             | SD_WP      |    |    |    |    |    |    | CMD | DAT |    |    |    |    |    |    |                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RU         |    |    |    |    |    |    | RU  | RU  |    |    |    |    |    |    |                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Reset</b>            | 1          |    |    |    |    |    |    | 1   | 0   | 0  | 0  | 0  | 1  | 1  | 1  | 1                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Bit</b>              | 15         | 14 | 13 | 12 | 11 | 10 | 9  | 8   | 7   | 6  | 5  | 4  | 3  | 2  | 1  | 0                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Name</b>             | CDDEBOUNCE |    |    |    |    |    |    |     |     |    |    |    |    |    |    |                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW         |    |    |    |    |    |    |     |     |    |    |    |    |    |    |                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Reset</b>            | 0          | 0  | 0  | 0  |    |    |    |     |     |    |    |    |    |    |    |                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                  |
|---------------|-----------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31            | <b>SDWP</b>     | SD_WP       | <b>Write protection switch status on SD memory card</b><br>The register bit shows the status of the write protection switch on the SD memory card. There is no default reset value. The write protection pin is only used when the controller is configured for the SD memory card. |

|       |               |            |                                                                                                                                                                                                                                                                             |
|-------|---------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24    | <b>CMD</b>    | CMD        | 1'bo: Write protection switch is ON. It means that memory card is write-protected.<br>1'b1: Write protection Switch is OFF. It means that memory card is writable.                                                                                                          |
| 23:16 | <b>DAT</b>    | DAT        | <b>Data line status</b><br>This bit reflects the command line value of the MSDC bus.                                                                                                                                                                                        |
| 15:12 | <b>CDDBCE</b> | CDDEBOUNCE | <b>Card detection de-bounce timer</b><br>This register field specifies the time interval for card de-bounce detection. The default value is 0. It means that de-bounce interval is one 32kHz cycle. Increase the counter by 1m to increase the interval by one clock cycle. |
| 1     | <b>CDSTS</b>  | CDSTS      | <b>Card detection status</b><br>1'bo: Card detection pin status is logic low<br>1'b1: Card detection pin status is logic high                                                                                                                                               |
| 0     | <b>CDEN</b>   | CDEN       | <b>Card detect enable</b><br>The register bit is used to control the card detection circuit.<br>1'bo: Card detection is disabled<br>1'b1: Card detection is enabled                                                                                                         |

## **A103000C MSDC INT**      **MSDC Interrupt Register**      **oooooooo**

| Bit(s) | Mnemonic          | Name        | Description                                                                                                            |
|--------|-------------------|-------------|------------------------------------------------------------------------------------------------------------------------|
| 19     | <b>DMAPROTECT</b> | DMA_PROTECT | This register identifies if there is a write operation to the DMA start address, length, start bit or last buffer bit. |
| 18     | <b>GPDCSERR</b>   | GPD_CS_ERR  | GPD checksum error detected                                                                                            |
| 17     | <b>BDCSERR</b>    | BD_CS_ERR   | BD checksum error detected                                                                                             |

|    |                  |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----|------------------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15 | <b>SDDCRCERR</b> | SD_DATA_CRCERR   | <b>SD Data CRC error interrupt</b><br>Indicates that MS/SD controller detects a CRC error after reading a block of data from the DAT line or SD/MMC signals a CRC error after writing a block of data to the DAT line.<br>1'bo: Otherwise<br>1'b1: MS/SD controller detected a CRC error after reading a block of data from the DAT line or SD/MMC signaled a CRC error after writing a block of data to the DAT line                                                                                                                    |
| 14 | <b>SDDTO</b>     | SD_DATTO         | <b>SD data timeout interrupt</b><br>Indicates that SD/MMC controller detects a timeout condition while waiting for data token on the DAT line.<br>This bit is for both data read and data write.<br>For SD data read, timeout will occur when the read data is not presented.<br>For SD data write, timeout will occur when the write data CRC status is not presented if PATCH_BIT[30] DETECT_WR_CRC_TIMEOUT = 1<br>1'bo: Otherwise<br>1'b1: SD/MMC controller detects a timeout condition while waiting for data token on the DAT line |
| 13 | <b>DMAXFDNE</b>  | DMA_XFER_DONE    | <b>DMA transfer done interrupt</b><br>The register bit indicates the status of data block transfer.<br>1'bo: Otherwise<br>1'b1: A data block was successfully transferred                                                                                                                                                                                                                                                                                                                                                                |
| 12 | <b>SDXF CPL</b>  | SD_XFER_COMPLETE | <b>SD Data transfer complete interrupt</b><br>This bit indicates the transaction is complete. While performing tuning procedure (execute tuning is set to 1), SD_XFER_COMPLETE is not set to 1.                                                                                                                                                                                                                                                                                                                                          |
| 11 | <b>SDCSTA</b>    | SD_CSTA          | <b>SD CSTA update interrupt</b><br>The register bit indicates any bit in the register SDC_CSTA is active, the register bit will be set to 1.<br>Software should clear the SDC_CSTA and this bit will be de-asserted automatically.<br>1'bo: No SD memory card interrupt<br>1'b1: SD memory card interrupt exists                                                                                                                                                                                                                         |
| 10 | <b>SDRCR CER</b> | SD_RESP_CRCERR   | <b>SD Command CRC error interrupt</b><br>Indicates that SD/MMC controller detected a CRC error after reading a response from the CMD line.<br>1'bo: Otherwise<br>1'b1: SD/MMC controller detected a CRC error after reading a response from the CMD line                                                                                                                                                                                                                                                                                 |
| 9  | <b>SDCTO</b>     | SD_CMDTO         | <b>SD Command timeout interrupt</b><br>Indicates that SD/MMC controller detected a timeout while waiting for a response on the CMD line.<br>1'bo: Otherwise                                                                                                                                                                                                                                                                                                                                                                              |

---

|   |                    |                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---|--------------------|-------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |                    |                         | 1'b1: SD/MMC controller detected a timeout condition while waiting for a response on the CMD line                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 8 | <b>SDCRDY</b>      | SD_CMDRDY               | <b>SD Command ready interrupt</b><br>For the command without response, the register bit will be 1 once the command is complete on SD/MMC bus.<br>For a command with response without busy, the register bit will be 1 whenever the command is issued onto SD/MMC bus and its corresponding response is received without CRC error.<br>For a command with response with busy in DATo, the register bit will be 1 whenever the command is issued onto SD/MMC bus and its corresponding response is received without CRC error and the DATo transited from busy to idle. |
| 7 | <b>SDIOIRQ</b>     | SD_SDIOIRQ              | 1'bo: Otherwise<br>1'b1: Command finished successfully without a CRC error                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 6 | <b>DMAQEPTY</b>    | DMA_Q_EMPTY             | <b>SD SDIO interrupt</b><br>This bit indicates an interrupt occurred in the SDIO bus.<br>1'bo: No interrupt on SDIO bus<br>1'b1: Interrupt on SDIO bus                                                                                                                                                                                                                                                                                                                                                                                                                |
| 5 | <b>SDACDRCRCER</b> | SD_AUTOCMD_RESP_ CRCERR | <b>DMA queue empty interrupt</b><br>This bit is used to indicate that the current DMA queue is empty. Only for Descriptor mode and Enhanced mode.                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 4 | <b>SDACDCTO</b>    | SD_AUTOCMD_CMDT O       | <b>SD auto command CRC error interrupt</b><br>This bit is set when detecting a CRC error in the Auto command response.                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 3 | <b>SDACDCRDY</b>   | SD_AUTOCMD_CMDR DY      | <b>SD auto command timeout interrupt</b><br>This bit is set if no response is returned within a specified cycle (64 clock cycles in spec) from the end bit of auto command.                                                                                                                                                                                                                                                                                                                                                                                           |
| 2 | <b>MSDCCDSC</b>    | MSDC_CDSC               | <b>SD auto command ready interrupt</b><br>This bit is set if auto command is executed without CRC error or time out.                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 1 | <b>MMCIRQ</b>      | MMC_IRQ                 | <b>MSDC Card detection status change interrupt</b><br>The register bit indicates if any interrupt for memory card insertion/removal exists. Whenever memory card is inserted or removed and card detection circuit is enabled, i.e., the register bit CDEN in the register MSDC_PS is set to 1, the register bit will be set to 1. It will be reset when the register is read.<br>1'bo: Otherwise<br>1'b1: Card is inserted or removed                                                                                                                                |
| 0 |                    |                         | <b>MMC card interrupt</b><br>1'bo: Otherwise<br>1'b1: Indicates that MMC card interrupt event occurred                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

---

**A1030010 MSDC\_INTEN****MSDC Interrupt Enable Register****oooooooooo**

| <b>Bit</b>   | 31                          | 30                  | 29                        | 28                          | 27                | 26                          | 25                  | 24                   | 23                     | 22                     | 21                                 | 20                               | 19                                | 18                   | 17                 | 16 |
|--------------|-----------------------------|---------------------|---------------------------|-----------------------------|-------------------|-----------------------------|---------------------|----------------------|------------------------|------------------------|------------------------------------|----------------------------------|-----------------------------------|----------------------|--------------------|----|
| <b>Name</b>  |                             |                     |                           |                             |                   |                             |                     |                      |                        |                        |                                    |                                  | <b>EN_DMA_PR_OTE</b>              | <b>EN_GPD_CS_ERR</b> | <b>EN_BD_CS_E</b>  |    |
| <b>Type</b>  |                             |                     |                           |                             |                   |                             |                     |                      |                        |                        |                                    |                                  | <b>RW</b>                         | <b>RW</b>            | <b>RW</b>          |    |
| <b>Reset</b> |                             |                     |                           |                             |                   |                             |                     |                      |                        |                        |                                    |                                  | <b>0</b>                          | <b>0</b>             | <b>0</b>           |    |
| <b>Bit</b>   | 15                          | 14                  | 13                        | 12                          | 11                | 10                          | 9                   | 8                    | 7                      | 6                      | 5                                  | 4                                | 3                                 | 2                    | 1                  | 0  |
| <b>Name</b>  | <b>EN_SD_DAT_A_C_RCE_RR</b> | <b>EN_SD_DAT_TO</b> | <b>EN_SD_XFER_ER_DONE</b> | <b>EN_SD_XFE_R_COMPLETE</b> | <b>EN_SD_CSTA</b> | <b>EN_SD_RES_P_C_RCE_RR</b> | <b>EN_SD_CMD_TO</b> | <b>EN_SD_CMD_RDY</b> | <b>EN_SD_S_DIOI_RQ</b> | <b>EN_DMA_Q_EMP_TY</b> | <b>EN_SD_AUTOCMD_R_ESP_CRC_ERR</b> | <b>EN_SD_AUTOCMD_D_CRC_MDT_O</b> | <b>EN_SD_AUTOCMD_D_CRC_MDR_DY</b> | <b>EN_MS_DC_DSC</b>  | <b>EN_MMCI IRQ</b> |    |
| <b>Type</b>  | <b>RW</b>                   | <b>RW</b>           | <b>RW</b>                 | <b>RW</b>                   | <b>RW</b>         | <b>RW</b>                   | <b>RW</b>           | <b>RW</b>            | <b>RW</b>              | <b>RW</b>              | <b>RW</b>                          | <b>RW</b>                        | <b>RW</b>                         | <b>RW</b>            | <b>RW</b>          |    |
| <b>Reset</b> | <b>0</b>                    | <b>0</b>            | <b>0</b>                  | <b>0</b>                    | <b>0</b>          | <b>0</b>                    | <b>0</b>            | <b>0</b>             | <b>0</b>               | <b>0</b>               | <b>0</b>                           | <b>0</b>                         | <b>0</b>                          | <b>0</b>             | <b>0</b>           |    |

| <b>Bit(s)</b> | <b>Mnemonic</b>     | <b>Name</b>                | <b>Description</b>                                                                                     |
|---------------|---------------------|----------------------------|--------------------------------------------------------------------------------------------------------|
| 19            | <b>ENDMAPROTECT</b> | <b>EN_DMA_PROTECT</b>      | <b>DMA protection interrupt enable</b><br>1'b0: Disable interrupt<br>1'b1: Enable interrupt            |
| 18            | <b>ENGPDPCSERR</b>  | <b>EN_GPD_CS_ERR</b>       | <b>GPD checksum error interrupt enable</b><br>1'b0: Disable interrupt<br>1'b1: Enable interrupt        |
| 17            | <b>ENBDCSERR</b>    | <b>EN_BD_CS_ERR</b>        | <b>BD checksum error interrupt enable</b><br>1'b0: Disable interrupt<br>1'b1: Enable interrupt         |
| 15            | <b>ENSDDCRCERR</b>  | <b>EN_SD_DATA_CRCERR</b>   | <b>SD Data CRC error interrupt enable</b><br>1'b0: Disable interrupt<br>1'b1: Enable interrupt         |
| 14            | <b>ENSDDTO</b>      | <b>EN_SD_DATTO</b>         | <b>SD Data timeout interrupt enable</b><br>1'b0: Disable interrupt<br>1'b1: Enable interrupt           |
| 13            | <b>ENDMAXFDNE</b>   | <b>EN_SD_DMA_XFER_DONE</b> | <b>DMA transfer done interrupt enable</b><br>1'b0: Disable interrupt<br>1'b1: Enable interrupt         |
| 12            | <b>ENSDXFCPL</b>    | <b>EN_SD_XFER_COMPLETE</b> | <b>SD Data transfer complete interrupt enable</b><br>1'b0: Disable interrupt<br>1'b1: Enable interrupt |
| 11            | <b>ENSDCSTA</b>     | <b>EN_SD_CSTA</b>          | <b>SD CSTA update interrupt enable</b><br>1'b0: Disable interrupt<br>1'b1: Enable interrupt            |
| 10            | <b>ENSDRCRcer</b>   | <b>EN_SD_RESP_CRCERR</b>   | <b>SD Command CRC error interrupt enable</b><br>1'b0: Disable interrupt                                |

|   |                      |                               |                                                                                                                |
|---|----------------------|-------------------------------|----------------------------------------------------------------------------------------------------------------|
|   |                      |                               | 1'b1: Enable interrupt                                                                                         |
| 9 | <b>ENSDCTO</b>       | EN_SD_CMDTO                   | <b>SD Command timeout interrupt enable</b><br>1'bo: Disable interrupt<br>1'b1: Enable interrupt                |
| 8 | <b>ENSDCRDY</b>      | EN_SD_CMDRDY                  | <b>SD Command ready interrupt enable</b><br>1'bo: Disable interrupt<br>1'b1: Enable interrupt                  |
| 7 | <b>ENSDIOIRQ</b>     | EN_SD_SDIOIRQ                 | <b>SD SDIO interrupt enable</b><br>1'bo: Disable interrupt<br>1'b1: Enable interrupt                           |
| 6 | <b>ENDMAQEPTY</b>    | EN_DMA_Q_EMPTY                | <b>DMA queue empty interrupt enable</b><br>1'bo: Disable interrupt<br>1'b1: Enable interrupt                   |
| 5 | <b>ENSDACDRCRGER</b> | EN_SD_AUTOCMD_RESP_C<br>RCERR | <b>SD auto command CRC error interrupt enable</b><br>1'bo: Disable interrupt<br>1'b1: Enable interrupt         |
| 4 | <b>ENSDACDCTO</b>    | EN_SD_AUTOCMD_CMDTO           | <b>SD auto command timeout interrupt enable</b><br>1'bo: Disable interrupt<br>1'b1: Enable interrupt           |
| 3 | <b>ENSDACDCRDY</b>   | EN_AUTOCMD_CMDRDY             | <b>SD auto command ready interrupt enable</b><br>1'bo: Disable interrupt<br>1'b1: Enable interrupt             |
| 1 | <b>ENMSDCCDSC</b>    | EN_MSDC_CDSC                  | <b>MSDC Card detection status change interrupt enable</b><br>1'bo: Disable interrupt<br>1'b1: Enable interrupt |
| 0 | <b>ENMMCIRQ</b>      | EN_MMCI IRQ                   | <b>MMC card interrupt enable</b><br>1'bo: Disable interrupt<br>1'b1: Enable interrupt                          |

**A1030014 MSDC FIFOCS**      **MSDC FIFO Control and Status Register**      **oooooooooo**

| Bit          | 31       | 30                              | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|----------|---------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  | FIFO CLR | <b>TXFIFOCNT</b>                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | Ao       | <b>RU</b>                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0        | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit          | 15       | 14                              | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  |          | <b>RXFIFOCNT</b>                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |          | <b>RU</b>                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |          | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit(s) | Mnemonic       | Name    | Description                                                                                                  |
|--------|----------------|---------|--------------------------------------------------------------------------------------------------------------|
| 31     | <b>FIFOCLR</b> | FIFOCLR | <b>Embedded FIFO clear</b><br>Write 1 into this bit to clear the FIFO. It returns to 0 when FIFO is cleared. |

---

|       |                  |           |                                                                                                                                                |
|-------|------------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                  |           | Software needs to check this bit to make sure clearing FIFO sequence is done.                                                                  |
|       |                  |           | This bit can be used when the data read/write sequence has an error.                                                                           |
| 23:16 | <b>TXFIFOCNT</b> | TXFIFOCNT | <b>TX FIFO count for MSDC write</b>                                                                                                            |
|       |                  |           | 8'd0: No data in FIFO<br>8'd1: 1 byte data in FIFO<br>8'd2: 2 bytes data in FIFO<br>8'd131: Maximum 131 bytes data in FIFO<br>Others: reserved |
| 7:0   | <b>RXFIFOCNT</b> | RXFIFOCNT | <b>RX FIFO count for MSDC read</b>                                                                                                             |
|       |                  |           | 8'd0: No data in FIFO<br>8'd1: 1 byte data in FIFO<br>8'd2: 2 bytes data in FIFO<br>8'd131: Maximum 131 bytes data in FIFO<br>Others: reserved |

---

**A1030018 MSDC TXDATA      MSDC TX Data Port Register      00000000**

| Bit          | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit          | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit(s) | Mnemonic         | Name       | Description                                                                                                                                                                        |
|--------|------------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | <b>PIOTXDATA</b> | PIO_TXDATA | <b>PIO mode TXDATA port</b><br>This register can be accessed by byte, half-word or word. This port can only be accessed in PIO mode. Otherwise, the transaction will be discarded. |

---

**A103001C MSDC RXDATA      MSDC RX Data Port Register      00000000**

| Bit          | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit          | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit(s) | Mnemonic         | Name       | Description                                                                                                                                                                        |
|--------|------------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | <b>PIORXDATA</b> | PIO_RXDATA | <b>PIO mode RXDATA port</b><br>This register can be accessed by byte, half-word or word. This port can only be accessed in PIO mode. Otherwise, the transaction will be discarded. |

---

| A1030030 SDC CFG |      |    |    |    |    |    |    |    |                  | SD Configuration Register |          |      |    |    |          |             |  |
|------------------|------|----|----|----|----|----|----|----|------------------|---------------------------|----------|------|----|----|----------|-------------|--|
| Bit              | 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23               | 22                        | 21       | 20   | 19 | 18 | 17       | 16          |  |
| Name             | DTOC |    |    |    |    |    |    |    | INT_AT_BLOCK_GAP | SDIO_INT_DE               | INT_SDIO | SDIO |    |    | BUSWIDTH | H           |  |
| Type             | RW   |    |    |    |    |    |    |    | RW               | RW                        | RW       |      |    |    | RW       |             |  |
| Reset            | 0    | 0  | 0  | 0  | 0  | 0  | 0  | 0  |                  |                           | 0        | 1    | 0  |    | 0        | 0           |  |
| Bit              | 15   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7                | 6                         | 5        | 4    | 3  | 2  | 1        | 0           |  |
| Name             |      |    |    |    |    |    |    |    |                  |                           |          |      |    |    | WAK      | EUP_SDI     |  |
| Type             |      |    |    |    |    |    |    |    |                  |                           |          |      |    |    | WAK      | EUP_OIN_TEN |  |
| Reset            |      |    |    |    |    |    |    |    |                  |                           |          |      |    |    | RW       | RW          |  |

| Bit(s) | Mnemonic | Name             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------|----------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24  | DTOC     | DTOC             | <p><b>Data Timeout Counter</b></p> <p>The period from the end of initial host read command or the last read data block in a multiple block read operation to the start bit of next read data block requires at least two serial clock cycles. The counter is used to extend the period (Read Data Access Time) in unit of 1048576 serial clocks.</p> <p>8'boooooooo: Extend 1048576 more serial clock cycle<br/> 8'booooooo1: Extend 1048576x2 more serial clock cycle<br/> 8'booooooo10: Extend 1048576x3 more serial clock cycle<br/> 8'b11111111: Extend 1048576x 256 more serial clock cycle</p>                                                                 |
| 21     | INTBGP   | INT_AT_BLOCK_GAP | <p><b>Interrupt at block gap</b></p> <p>This bit is valid only in 4-bit mode of the SDIO card and selects a sample point in the interrupt cycle. Setting to 1 enables interrupt detection at the block gap for a multiple block transfer. Setting to 0 disables interrupt detection during a multiple block transfer. If the SD card cannot signal an interrupt during a multiple block transfer, this bit should be set to 0. When the Host Driver detects an SD card insertion, it shall set this bit according to the CCCR of the SDIO card.</p> <p>1'b0: Disable interrupt detection at the block gap<br/> 1'b1: Enable interrupt detection at the block gap</p> |
| 20     | SDIOIDE  | SDIO_INT_DET_EN  | <p><b>SDIO interrupt detection enable</b></p> <p>This bit is to inform the SD controller to sense the SDIO interrupt</p> <p>1'b0: SDIO interrupt detection is disabled<br/> 1'b1: SDIO interrupt detection is enabled if the SDIO</p>                                                                                                                                                                                                                                                                                                                                                                                                                                |

|       |                      |                       |                                                                                                                                                                                                                                 |
|-------|----------------------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19    | <b>SDIO</b>          | SDIO                  | bit is also on<br><b>SDIO mode enable bit</b><br>This bit is to enable the support to sense the SDIO interrupt and disable the R4 response CRC check for SDIO card<br>1'bo: SDIO mode is disabled<br>1'b1: SDIO mode is enabled |
| 17:16 | <b>BUSWD</b>         | BUSWIDTH              | <b>Bus width configuration</b><br>This field is used to define the SD/MMC bus width<br>2'boo: 1 bit mode<br>2'bo1: 4 bit mode<br>2'b10: 8 bit mode<br>2'b11: reserved                                                           |
| 1     | <b>ENWKUPINS</b>     | WAKEUP_INS_EN         | <b>Card status change wakeup event enable bit</b><br>1'bo: Disable wakeup event for card status change<br>1'b1: Enable wakeup event for card status change                                                                      |
| 0     | <b>ENWKUPSDIOINT</b> | WAKEUP_SDIOINT_E<br>N | <b>SDIO card interrupt wakeup event enable bit</b><br>1'bo: Disable wakeup event for SDIO card interrupt<br>1'b1: Enable wakeup event for SDIO card interrupt                                                                   |

**A1030034 SDC CMD SD Command Register 00000000**

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------------|-----------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 28            | <b>ACMD</b>     | AUTO_CMD    | <p><b>Auto command enable</b></p> <p>This field determines use of auto command functions.</p> <p>This function can be used in all modes including PIO/Basic DMA/Descriptor DMA/Enhanced Mode.</p> <p>There are two methods to stop Multiple-block read and write operation.</p> <p>(1) Auto CMD12 Enable</p> <p>Multiple-block read and write commands for memory require CMD12 to stop the operation. When ACMD-12 is used, MSDC issues CMD12 automatically when last block transfer completes. Auto CMD12 error is indicated to the MSDC_INT register. The Host Driver shall not set this bit if the command does not require CMD12. In particular, secure commands defined in the</p> |

|       |              |        |
|-------|--------------|--------|
| 27:16 | <b>LEN</b>   | LEN    |
| 15    | <b>GOIRQ</b> | GO_IRQ |
| 14    | <b>STOP</b>  | STOP   |
| 13    | <b>RW</b>    | RW     |

Part 3 File Security specification do not require CMD12.

#### (2) Auto CMD23 Enable

When ACMD-23 is used, MSDC issues a CMD23 automatically before issuing a command specified in the CMD field. The Host Controller Version 3.00 and later shall support this function. By writing the Command register, MSDC issues a CMD23 first and then issues a command specified by the CMD field in SDC\_CMD register. If response errors of CMD23 are detected, the second command is not issued. A CMD23 error is indicated in the MSDC\_INT register. 32-bit block count value for CMD23 is set to SDC\_BLOCK\_NUM register.

1'b0: Disable Auto Command

1'b1: Enable Auto CMD12

#### Length

The register field is used to define the length of one block in unit of byte in a data transaction of block mode or the data length in unit of byte in data transaction of byte mode. The maximal value of block length is 2048 bytes.

12'booooooooooooo: Reserved

12'booooooooooooo1: Block length is 1 byte

12'booooooooooooo10: Block length is 2 byte

12'b011111111111: Block length is 2047 byte

12'b100000000000: Block length is 2048 byte

#### GO\_IRQ command

The register bit indicates if the command is GO\_IRQ\_STATE (CMD40) and used only for MMC protocol. If the command is GO\_IRQ\_STATE, the period between command token and response token will not be limited.

1'b0: The command is not GO\_IRQ\_STATE

1'b1: The command is GO\_IRQ\_STATE

#### Stop command

The register bit indicates if the command is a stop transmission command. It should be set to 1 when CMD12 (SD/MMC) or CMD52 with I/O abort (SDIO) is to be issued.

1'b0: The command is not a stop transmission command

1'b1: The command is a stop transmission command

#### Command read write selection

The register bit defines if the command is a read command or write command. The register bit is valid only when the command will cause a transaction with data token.

12:11      **DTYPE**

DTYPE

1'bo: The command is a read command

1'b1: The command is a write command

9:7      **RSPTYP**

RSPTYP

**Data block selection**

The register field defines data token type for the command.

2'boo: No data token for the command

2'bo1: Single block transaction (only available in block mode)

2'b10: Multiple block transaction. (only available in block mode)

2'b11: Stream operation. It only shall be used in MMC protocol. (only available in block mode)

**Command response type**

3'booo: This command has no response.

3'bo01: The command has R1/R5/R6/R7 response. The response token is 48-bit with CRC check (For SD/MMC/SDIO) (Not including the SDIO abort command)

3'bo10: The command has R2 response. The response token is 136-bit (For SD/MMC)

3'bo11: The command has R3 response. The response token is 48-bit response, no CRC check (For SD/MMC)

3'b100: The command has R4 response. The response token is 48-bit without CRC check (For SDIO) The response token is 48-bit with CRC check (For MMC)

3'b111: The command has R1b response. The response token is 48-bit (For SD/MMC/SDIO)

6      **BREAK**

BREAK

**Abort a pending MMC GO\_IRQ command**

It is only valid for a pending GO\_IRQ\_MODE command waiting for MMC interrupt response.

1'bo: Not a break command

1'b1: Break a pending MMC GO\_IRQ\_MODE command in the controller.

5:0      **CMD**

CMD

**SD Memory Card command****A1030038 SDC ARG****SD Argument Register****00000000**

| <b>Bit</b>   | 31         | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  | <b>ARG</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | <b>RW</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | o          | o  | o  | o  | o  | o  | o  | o  | o  | o  | o  | o  | o  | o  | o  | o  |
| <b>Bit</b>   | 15         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | <b>ARG</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | <b>RW</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | o          | o  | o  | o  | o  | o  | o  | o  | o  | o  | o  | o  | o  | o  | o  | o  |

**Bit(s)****Mnemonic****Name****Description**

31:0      ARG

ARG

Memory card controller argument register

| <b>A103003C SDC_STS</b> |                      | <b>SD Status Register</b> |           |           |           |           |           |           |           |           |           |           |           |           |           | <b>oooooooooooo</b> |         |  |  |
|-------------------------|----------------------|---------------------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|---------------------|---------|--|--|
| <b>Bit</b>              | <b>31</b>            | <b>30</b>                 | <b>29</b> | <b>28</b> | <b>27</b> | <b>26</b> | <b>25</b> | <b>24</b> | <b>23</b> | <b>22</b> | <b>21</b> | <b>20</b> | <b>19</b> | <b>18</b> | <b>17</b> | <b>16</b>           |         |  |  |
| <b>Name</b>             | MMC_STREA<br>M_WRCPL |                           |           |           |           |           |           |           |           |           |           |           |           |           |           | CMDWRBU<br>SY       |         |  |  |
| <b>Type</b>             | RU                   |                           |           |           |           |           |           |           |           |           |           |           |           |           |           | W1C                 |         |  |  |
| <b>Reset</b>            | 0                    |                           |           |           |           |           |           |           |           |           |           |           |           |           |           | 0                   |         |  |  |
| <b>Bit</b>              | <b>15</b>            | <b>14</b>                 | <b>13</b> | <b>12</b> | <b>11</b> | <b>10</b> | <b>9</b>  | <b>8</b>  | <b>7</b>  | <b>6</b>  | <b>5</b>  | <b>4</b>  | <b>3</b>  | <b>2</b>  | <b>1</b>  | 0                   |         |  |  |
| <b>Name</b>             |                      |                           |           |           |           |           |           |           |           |           |           |           |           |           |           | CMDBUSY             | SDCBUSY |  |  |
| <b>Type</b>             |                      |                           |           |           |           |           |           |           |           |           |           |           |           |           |           | RU                  | RU      |  |  |
| <b>Reset</b>            |                      |                           |           |           |           |           |           |           |           |           |           |           |           |           |           | 0                   | 0       |  |  |

| <b>Bit(s)</b> | <b>Mnemonic</b>   | <b>Name</b>     | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------------|-------------------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31            | <b>MMCSWRCPPL</b> | MMC_STREAM_WR_C | <b>MMC Stream mode write data is all flushed to MMC card</b><br><br>Software can use this bit to confirm last write data are flushed to MMC then issue a STOP command.<br><br>This bit is only valid when the command SDC_CMD.DTYPE=2'b11.<br><br>1'bo: Last Data are partially inside MSDC<br>1'b1: Last data are flushed to MMC card                                                                                                                                                                                                                |
| 16            |                   | CMD_WR_BUSY     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 1             | <b>CMDBSY</b>     | CMDBUSY         | <b>SD Command line busy status</b><br><br>Software should always read this bit to make sure the command line is not busy before sending the next command.<br><br>If the command is R1B or data read/write command, Software should check the SDCBUSY bit, too.<br><br>Note: When auto command 12 is enabled, this bit will be asserted immediately after SDC_CMD is written and de-asserted after auto command 12 finishes.<br><br>1'bo: No transmission going on in CMD line on SD bus<br>1'b1: There is transmission going on in CMD line on SD bus |
| 0             | <b>SDCBSY</b>     | SDCBUSY         | <b>SD controller busy status</b><br><br>1'bo: SD controller is idle<br>1'b1: SD controller is busy                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

| <b>A1030040 SDC_RESPo</b> |           | <b>SD Response Register o</b> |           |           |           |           |           |           |           |           |           |           |           |           |           | <b>oooooooooooo</b> |  |  |  |
|---------------------------|-----------|-------------------------------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|-----------|---------------------|--|--|--|
| <b>Bit</b>                | <b>31</b> | <b>30</b>                     | <b>29</b> | <b>28</b> | <b>27</b> | <b>26</b> | <b>25</b> | <b>24</b> | <b>23</b> | <b>22</b> | <b>21</b> | <b>20</b> | <b>19</b> | <b>18</b> | <b>17</b> | <b>16</b>           |  |  |  |
| <b>Name</b>               |           |                               |           |           |           |           |           |           |           |           |           |           |           |           |           | <b>RESPo</b>        |  |  |  |
| <b>Type</b>               |           |                               |           |           |           |           |           |           |           |           |           |           |           |           |           | RU                  |  |  |  |
| <b>Reset</b>              | 0         | 0                             | 0         | 0         | 0         | 0         | 0         | 0         | 0         | 0         | 0         | 0         | 0         | 0         | 0         | 0                   |  |  |  |
| <b>Bit</b>                | <b>15</b> | <b>14</b>                     | <b>13</b> | <b>12</b> | <b>11</b> | <b>10</b> | <b>9</b>  | <b>8</b>  | <b>7</b>  | <b>6</b>  | <b>5</b>  | <b>4</b>  | <b>3</b>  | <b>2</b>  | <b>1</b>  | 0                   |  |  |  |
| <b>Name</b>               |           |                               |           |           |           |           |           |           |           |           |           |           |           |           |           | <b>RESPo</b>        |  |  |  |

| Type  | RU |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|-------|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Reset | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| Bit(s) | Mnemonic | Name  | Description                                |
|--------|----------|-------|--------------------------------------------|
| 31:0   | RESPo    | RESPo | Memory card controller response register o |

| <b>A1030044 SDC RESP1 SD Response Register 1 00000000</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-----------------------------------------------------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Bit</b>                                                | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b>                                               | <b>RESP1</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                                               | RU           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                                              | 0            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>                                                | 15           | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>                                               | <b>RESP1</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                                               | RU           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                                              | 0            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Mnemonic | Name  | Description                                |
|--------|----------|-------|--------------------------------------------|
| 31:0   | RESP1    | RESP1 | Memory card controller response register 1 |

| <b>A1030048 SDC RESP2 SD Response Register 2 00000000</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-----------------------------------------------------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Bit</b>                                                | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b>                                               | <b>RESP2</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                                               | RU           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                                              | 0            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>                                                | 15           | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>                                               | <b>RESP2</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                                               | RU           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                                              | 0            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Mnemonic | Name  | Description                                |
|--------|----------|-------|--------------------------------------------|
| 31:0   | RESP2    | RESP2 | Memory card controller response register 2 |

| <b>A103004C SDC RESP3 SD Response Register 3 00000000</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-----------------------------------------------------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Bit</b>                                                | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b>                                               | <b>RESP3</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                                               | RU           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                                              | 0            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>                                                | 15           | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>                                               | <b>RESP3</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                                               | RU           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                                              | 0            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Mnemonic | Name  | Description                                |
|--------|----------|-------|--------------------------------------------|
| 31:0   | RESP3    | RESP3 | Memory card controller response register 3 |

| <b>A1030050 SDC BLK_NUM SD Block Number Register 00000001</b> |                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|---------------------------------------------------------------|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Bit</b>                                                    | 31                  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b>                                                   | <b>BLOCK_NUMBER</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                                                   | RW                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit(s) | Mnemonic      | Name         | Description                                                                                                                                                                                                                                                                                                          |
|--------|---------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | <b>BLKNUM</b> | BLOCK_NUMBER | <p><b>Memory card controller Block number</b></p> <p>This field indicates the block number of data transaction.</p> <ul style="list-style-type: none"> <li>32'd0: Reserved</li> <li>32'd1: 1 data block</li> <li>32'd2: 2 data block</li> <li>32'd3: 3 data block</li> <li>32'hffffffff: 4GB-1 data block</li> </ul> |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b> | <b>Description</b>                                                                                                                                                                       |
|---------------|-----------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0          | <b>CSTS</b>     | CSTS        | <p>The register provides SD/MMC card status in the response R1 or R1b field.</p> <p>32'ho: keep the current value</p> <p>Others: write 1 to each bit to clear the corresponding bit.</p> |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b> | <b>Description</b>                                                               |
|---------------|-----------------|-------------|----------------------------------------------------------------------------------|
| 31:0          | CSTS_EN         | CSTS_EN     | This register is used to control the CSTA bit that will generate MSDC_INT.SDCSTA |

**A1030060 SDC DATCRC STS SD Card Data CRC Status Register 00000000**

|              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------|
| <b>Bit</b>   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                    |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                     |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>DAT_CRCSTS_POS</b> |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>RU</b>             |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    | 0  | 0  | 0  | 0  | 0  | 0                     |

| Bit(s) | Mnemonic     | Name                  | Description                                                                                                                                                                   |
|--------|--------------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0    | <b>DCSSP</b> | <b>DAT_CRCSTS_POS</b> | <b>MSDC read DATA CRC status</b><br>This register reflects the CRC status of data line[7:0].<br>This register is only for MSDC Read.<br>1'b0: No CRC error<br>1'b1: CRC error |

| <b>A1030080 SD_ACMD_RESP SD ACMD Response Register 00000000</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                     |
|-----------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------|
| <b>Bit</b>                                                      | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                  |
| <b>Name</b>                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>AUTOCMD_RESP</b> |
| <b>Type</b>                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>RU</b>           |
| <b>Reset</b>                                                    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                   |
| <b>Bit</b>                                                      | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                   |
| <b>Name</b>                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>AUTOCMD_RESP</b> |
| <b>Type</b>                                                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>RU</b>           |
| <b>Reset</b>                                                    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                   |

| Bit(s) | Mnemonic        | Name                | Description                                                                                                   |
|--------|-----------------|---------------------|---------------------------------------------------------------------------------------------------------------|
| 31:0   | <b>ACMDRESP</b> | <b>AUTOCMD_RESP</b> | <b>SD Auto command response register</b><br>This register stores the response [39:8] of ACMD12/ACMD23/ACMD19. |

| <b>A1030090 DMA_SA DMA Start Address Register 00000000</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                     |
|------------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------|
| <b>Bit</b>                                                 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                  |
| <b>Name</b>                                                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>DMA_STR_ADDR</b> |
| <b>Type</b>                                                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>RW</b>           |
| <b>Reset</b>                                               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                   |
| <b>Bit</b>                                                 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                   |
| <b>Name</b>                                                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>DMA_STR_ADDR</b> |
| <b>Type</b>                                                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>RW</b>           |
| <b>Reset</b>                                               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                   |

| Bit(s) | Mnemonic     | Name                | Description                                                                                                                                                                                                                                                                                                |
|--------|--------------|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | <b>DMASA</b> | <b>DMA_STR_ADDR</b> | <b>The start address of the DMA address</b><br>This register is used to set the start address of the DMA. In DMA basic mode, this field indicates the source or destination address of the data transfer which depends on the command. In Descriptor DMA mode, this is the descriptor chain start address. |

| <b>A1030094 DMA_CA DMA Current Address Register 00000000</b> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|--------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
|--------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|

|              |                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|--------------|----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Bit</b>   | 31                   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b>  | <b>DMA_CURR_ADDR</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RU                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>   | 15                   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | <b>DMA_CURR_ADDR</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RU                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Mnemonic     | Name                 | Description                                                                                                                     |
|--------|--------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | <b>DMACA</b> | <b>DMA_CURR_ADDR</b> | <b>The current address of the DMA address</b><br>This register is used to read the current address of the DMA descriptor chain. |

| <b>A1030098 DMA_CTRL DMA Control Register 00006000</b> |    |                   |    |    |                      |                 |                   |                  |    |    |    |    |    |                   |                  |                   |
|--------------------------------------------------------|----|-------------------|----|----|----------------------|-----------------|-------------------|------------------|----|----|----|----|----|-------------------|------------------|-------------------|
| <b>Bit</b>                                             | 31 | 30                | 29 | 28 | 27                   | 26              | 25                | 24               | 23 | 22 | 21 | 20 | 19 | 18                | 17               | 16                |
| <b>Name</b>                                            |    |                   |    |    |                      |                 |                   |                  |    |    |    |    |    |                   |                  |                   |
| <b>Type</b>                                            |    |                   |    |    |                      |                 |                   |                  |    |    |    |    |    |                   |                  |                   |
| <b>Reset</b>                                           |    |                   |    |    |                      |                 |                   |                  |    |    |    |    |    |                   |                  |                   |
| <b>Bit</b>                                             | 15 | 14                | 13 | 12 | 11                   | 10              | 9                 | 8                | 7  | 6  | 5  | 4  | 3  | 2                 | 1                | 0                 |
| <b>Name</b>                                            |    | <b>BURST_SIZE</b> |    |    | <b>DMA_SPLI_T_1K</b> | <b>LAST_BUF</b> | <b>DMA_ALI_GN</b> | <b>DMA_MO_DE</b> |    |    |    |    |    | <b>DMA_RESUME</b> | <b>DMA_STO_P</b> | <b>DMA_STA_RT</b> |
| <b>Type</b>                                            |    | RW                |    |    | RW                   | RW              | RW                | RW               |    |    |    |    |    | WO                | Ao               | WO                |
| <b>Reset</b>                                           |    | 1                 | 1  | 0  | 0                    | 0               | 0                 | 0                |    |    |    |    |    | 0                 | 0                | 0                 |

| Bit(s) | Mnemonic        | Name                | Description                                                                                                                                                                                                                                                              |
|--------|-----------------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14:12  | <b>BSTSZ</b>    | <b>BURST_SIZE</b>   | <b>DMA burst size</b><br>This field is used to specify the maximum transfer bytes allowed at the device per DMA burst. This field cannot be modified when the DMA status is 1.<br>3'd3: 8 Bytes<br>3'd4: 16 Bytes<br>3'd5: 32 Bytes<br>3'd6: 64 Bytes<br>Other: Reserved |
| 11     | <b>SPLIT1K</b>  | <b>DMA_SPLIT_1K</b> | <b>This field is used to specify whether to split burst when it crosses the 1K address boundary</b><br>1'b0:1K boundary not split<br>1'b1:1K boundary split                                                                                                              |
| 10     | <b>LASTBF</b>   | <b>LAST_BUF</b>     | <b>Last buffer of the basic DMA mode</b><br>This field indicates the last buffer in the basic DMA mode                                                                                                                                                                   |
| 9      | <b>DMAALIGN</b> | <b>DMA_ALIGN</b>    | <b>This field is used to specify whether there is address alignment burst size</b><br>1'b0:No DMA burst size alignment<br>1'b1:DMA burst size alignment                                                                                                                  |
| 8      | <b>DMAMOD</b>   | <b>DMA_MODE</b>     | <b>DMA operation mode</b>                                                                                                                                                                                                                                                |

|   |                 |            |                                                                                                                                                                                                                 |
|---|-----------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |                 |            | This field indicates the operation mode of DMA<br>1'bo: Basic DMA mode<br>1'b1: Descriptor base DMA mode                                                                                                        |
| 2 | <b>DMARSM</b>   | DMA_RESUME | <b>DMA resume control register</b><br>This bit is used to resume the DMA transaction. Read always returns 0                                                                                                     |
| 1 | <b>DMASTOP</b>  | DMA_STOP   | <b>DMA Stop control register</b><br>This bit is used to stop the DMA transaction. When software issues STOP command, it must wait for this bit to de-assert or inactivate the DMA to guarantee a complete stop. |
| 0 | <b>DMASTART</b> | DMA_START  | <b>DMA start control register</b><br>This bit is used to start the DMA transaction. Read always returns 0                                                                                                       |

| A103009C DMA CFG |    |    |                 |    |    |    |                |    |    |    |    |    |    |    |    | DMA Configuration Register |      |                   |             | 00000000 |
|------------------|----|----|-----------------|----|----|----|----------------|----|----|----|----|----|----|----|----|----------------------------|------|-------------------|-------------|----------|
| Bit              | 31 | 30 | 29              | 28 | 27 | 26 | 25             | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                         | Name | DMA_CH_K_SUM_12_B |             |          |
| Type             |    |    |                 |    |    |    |                |    |    |    |    |    |    |    |    |                            | RW   |                   |             |          |
| Reset            |    |    |                 |    |    |    |                |    |    |    |    |    |    |    |    |                            | 0    |                   |             |          |
| Bit              | 15 | 14 | 13              | 12 | 11 | 10 | 9              | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                          | Name | DMA_DSC_P_CS_EN   | DMA_STA_TUS |          |
| Type             |    |    | MSDC_ACT_IYE_EN |    |    |    | AHB_HPROT_2_EN |    |    |    |    |    |    |    |    |                            | RW   | RU                |             |          |
| Reset            |    |    | 0 0             |    |    |    | 0 0            |    |    |    |    |    |    |    |    |                            | 0    | 0                 |             |          |

| Bit(s) | Mnemonic            | Name            | Description                                                                                                                                                                                                                                                                                               |
|--------|---------------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16     | <b>DMACHKSUM12B</b> | DMA_CHK_SUM_12B | This register indicates GPD/BD checksum length is 16bytes or 12bytes<br>1'bo: GPD/BD checksum cover 16byte<br>1'b1: GPD/BD checksum only cover 12byte                                                                                                                                                     |
| 13:12  | <b>MSDCACTIVEEN</b> | MSDC_ACTIVE_EN  | This register indicates how to control msdc_active<br>2'boo: dynamic control msdc_active<br>2'b01: msdc_active = 0<br>2'b10: msdc_active = 1<br>2'b11: Reserved                                                                                                                                           |
| 9:8    | <b>AHBHPROT2EN</b>  | AHB_HPROT_2_EN  | This register determines how to control hprot_2 pin of AHB bus<br>AHB_HPROT_2_EN = 2'boo, and Basic DMA Mode<br>All write transfers of a burst are accessed in bufferable mode except the last DMA burst<br>AHB_HPROT2_2_EN=2'boo, and Descriptor DMA Mode all write transfers of a burst are accessed in |

|        |                         |                |                                                                                                                                                    |
|--------|-------------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------|
|        |                         |                | bufferable mode except the hardware's own update transfer.                                                                                         |
| 2'bo:  | dynamic control hprot_2 |                |                                                                                                                                                    |
| 2'b01: | hprot_2 = 0             |                |                                                                                                                                                    |
| 2'b10: | hprot_2 = 1             |                |                                                                                                                                                    |
| 1      | <b>DSCPCSEN</b>         | DMA_DSCP_CS_EN | <b>DMA descriptor checksum enable</b>                                                                                                              |
|        |                         |                | This bit is used to enable or disable the checksum validation function for the descriptor. This field cannot be modified when the DMA status is 1. |
| 0      | <b>DMASTS</b>           | DMA_STATUS     | <b>DMA status</b>                                                                                                                                  |
|        |                         |                | This bit is used to indicate the status of the DMA.                                                                                                |
|        |                         |                | 1'bo: DMA engine is inactive                                                                                                                       |
|        |                         |                | 1'b1: DMA engine is active                                                                                                                         |

**A10300Ao SW DBG SEL MSDC S/W Debug Selection Register 00000000**

| Bit          | 31             | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Bit</b>   | 15             | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | <b>DBG_SEL</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0              | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Mnemonic        | Name    | Description                             |
|--------|-----------------|---------|-----------------------------------------|
| 15:0   | <b>SWDBGSEL</b> | DBG_SEL | <b>MSDC debug selection</b><br>Reserved |

**A10300A4 SW DBG OUT MSDC S/W Debug Output Register 00000000**

| Bit          | 31             | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | <b>DBG_OUT</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0              | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>   | 15             | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | <b>DBG_OUT</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RU             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0              | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Mnemonic      | Name    | Description                                                               |
|--------|---------------|---------|---------------------------------------------------------------------------|
| 31:0   | <b>SWDBGO</b> | DBG_OUT | <b>MSDC debug output</b><br>32 bit output selected by SW_DBG_SEL register |

**A10300A8 DMA\_LENGTH DMA Length Register 00000000**

| Bit          | 31               | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  |                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | <b>XFER_SIZE</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>   | 15               | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |

| Name  | XFER_SIZE |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|-------|-----------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Type  | RW        |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| Reset | 0         | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| Bit(s) | Mnemonic | Name      | Description                                                                                                                                   |
|--------|----------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | XFSZ     | XFER_SIZE | <b>DMA total transfer size</b><br>This field is used to specify the number of DMA transfer bytes. This field is only valid in basic DMA mode. |

| A10300Bo PATCH BITo MSDC Patch Bit Register o 403C004F |                      |                              |                         |                |                     |                     |                      |    |    |    |                |    |    |    |                                |    |
|--------------------------------------------------------|----------------------|------------------------------|-------------------------|----------------|---------------------|---------------------|----------------------|----|----|----|----------------|----|----|----|--------------------------------|----|
| Bit                                                    | 31                   | 30                           | 29                      | 28             | 27                  | 26                  | 25                   | 24 | 23 | 22 | 21             | 20 | 19 | 18 | 17                             | 16 |
| Name                                                   | EN_MMCDRVRESPTIMEOUT | DETECTWR_ALWSPC_AYS_PUSHPUSH | SPC_ALWSPC_AYS_PUSHPUSH | SDIOINT_DLYSEL | SDCCMD_CMDFAI_L_SEL | SDCCMD_CMDFAI_L_SEL | SDC_CFG_WDOD         |    |    |    | SDC_CFG_BSYDLY |    |    |    | SDIOCFG_INTC_SEL               |    |
| Type                                                   | RW                   | RW                           | RW                      | RW             | RW                  | RW                  | RW                   |    |    |    | RW             |    |    |    | RW                             |    |
| Reset                                                  | 0                    | 1                            | 0                       | 0              | 0                   | 0                   | 0                    | 0  | 0  | 0  | 1              | 1  | 1  | 1  | 0                              |    |
| Bit                                                    | 15                   | 14                           | 13                      | 12             | 11                  | 10                  | 9                    | 8  | 7  | 6  | 5              | 4  | 3  | 2  | 1                              | 0  |
| Name                                                   | MSDC_FI              |                              |                         |                |                     |                     | INT_DAT_LATCH_CK_SEL |    |    |    | reserved1      |    |    |    | DIS_REFLECTIVE_CMD_WREN_N_BS_Y |    |
| Type                                                   | RW                   |                              |                         |                |                     |                     | RW                   |    |    |    | RW             |    |    |    | RW                             |    |
| Reset                                                  | 0                    |                              |                         |                |                     |                     | 0                    | 0  | 0  | 1  | 0              | 0  | 1  | 1  | 1                              |    |

| Bit(s) | Mnemonic | Name                  | Description                                                                                                                                                                                           |
|--------|----------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31     | PTCH31   | EN_MMCDRVRESP         | Enable MSDC always drives the bus, when the output is a wakeup response, such as BREAK.<br>1'b0: Disable<br>1'b1: Enable                                                                              |
| 30     | PTCH30   | DETECT_WR_CRC_TIMEOUT | <b>MSDC write data CRC phase timeout detection</b><br>1'b0: Does not detect CRC phase timeout<br>1'b1: Detects CRC phase timeout                                                                      |
| 29     | PTCH29   | SPC_ALWAYS_PUSH       | <b>SPC Buffer push mechanism</b><br>1'b0: Push the buffer only when read transfer is on-going<br>1'b1: Always push the buffer                                                                         |
| 28     | PTCH28   | SDIO_INT_DLY_SEL      | <b>SDIO interrupt latch time selection</b><br>1'b0: Latch the data line value in internal SDIO interrupt period<br>1'b1: Latch the data line value in 1 clock delay of internal SDIO interrupt period |

|       |               |                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------|---------------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27    | <b>PTCH27</b> | SDC_CMD_CMDFAIL_SEL | <b>SDIO interrupt period recovery selection</b><br>1'bo: SDIO interrupt period will re-start after a CMD12 or CMD52 command is issued<br>1'b1: SDIO interrupt period whenever DAT line is not busy                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 26    | <b>PTCH26</b> | SDC_CMD_IDRT_SEL    | <b>SD identification response time selection</b><br>The register bit indicates if the command has a response with NID (that is, 5 serial clock cycles as defined in SD Memory Card Specification Part 1 Physical Layer Specification version 1.0) response time. The register bit is valid only when the command has a response token. Thus, the register bit must be set to 1 for CMD2 (ALL_SEND_CID) and ACMD41 (SD_APP_OP_CMD).<br>1'bo: Otherwise.<br>1'b1: The command has a response with NID response time.                                                                                                                                                                                                                                    |
| 25:22 | <b>PTCH22</b> | SDC_CFG_WDOD        | <b>SD Write Data Output Delay</b><br>The period from response finish for the initial host write command or the last write data block in a multiple block write operation to the start bit of the next write data block requires at least two serial clock cycles. The register field is used to extend the period (Write Data Output Delay) in the unit of one serial clock.<br>4'boooo: Not extended.<br>4'booo1: Extended by one more serial clock cycle.<br>4'boo10: Extended by two more serial clock cycles.<br>4'b111: Extended by fifteen more serial clock cycles.                                                                                                                                                                            |
| 21:18 | <b>PTCH18</b> | SDC_CFG_BSYDLY      | <b>SD R1B busy detection mode</b><br>The register field is only valid for the commands with R1b response. If the command has a response of R1b type, MS/SD controller must monitor the data line o for card busy status from the bit time that is two serial clock cycles after the command end bit to check if operations in SD/MMC Memory Card have finished. The register field is used to expand the time between the command end bit and end of detection period to detect card busy status. If time is up and there is no card busy status on data line o, then the controller will abandon the detection.<br>4'boooo: Not extended.<br>4'booo1: Extended by one more serial clock cycle.<br>4'boo10: Extended by two more serial clock cycles. |

|     |               |                            |  |  |  |  |  |  |  |  |  |  |  |  |                                                 |                                                        |  |  |
|-----|---------------|----------------------------|--|--|--|--|--|--|--|--|--|--|--|--|-------------------------------------------------|--------------------------------------------------------|--|--|
|     |               |                            |  |  |  |  |  |  |  |  |  |  |  |  |                                                 |                                                        |  |  |
| 17  | <b>PTCH17</b> | SDIO_CFG_INTC_SEL          |  |  |  |  |  |  |  |  |  |  |  |  |                                                 |                                                        |  |  |
| 15  | <b>PTCH15</b> | MSDC_FIFO_RD_DIS           |  |  |  |  |  |  |  |  |  |  |  |  |                                                 |                                                        |  |  |
| 9:7 | <b>INTCKS</b> | INT_DAT_LATCH_CK_SEL       |  |  |  |  |  |  |  |  |  |  |  |  |                                                 |                                                        |  |  |
| 6:3 |               | reserved1                  |  |  |  |  |  |  |  |  |  |  |  |  |                                                 |                                                        |  |  |
| 2   | <b>PTCH02</b> | DIS_REFLECT_CMDWR_WHEN_BSY |  |  |  |  |  |  |  |  |  |  |  |  | <b>Enable SD command register write monitor</b> |                                                        |  |  |
| 1   | <b>PTCH01</b> | EN_SDC_ODD_8BIT_SUP        |  |  |  |  |  |  |  |  |  |  |  |  |                                                 | <b>Enable SD odd number support for 8-bit data bus</b> |  |  |
| 0   |               | reserved0                  |  |  |  |  |  |  |  |  |  |  |  |  |                                                 |                                                        |  |  |

| <b>A10300B4 PATCH BIT1</b> |                                 |                               |                             |                               |                             |                                |                   |                       |                     |                     |           |                    |           |                    | <b>MSDC Patch Bit Register 1</b> |                    |                              |  |
|----------------------------|---------------------------------|-------------------------------|-----------------------------|-------------------------------|-----------------------------|--------------------------------|-------------------|-----------------------|---------------------|---------------------|-----------|--------------------|-----------|--------------------|----------------------------------|--------------------|------------------------------|--|
| <b>Bit</b>                 | 31                              | 30                            | 29                          | 28                            | 27                          | 26                             | 25                | 24                    | 23                  | 22                  | 21        | 20                 | 19        | 18                 | 17                               | 16                 |                              |  |
| <b>Name</b>                | MSD_C_CK<br>SHB_RCT<br>FF_C_KEN | MSD_C_CK<br>WC_L_CK<br>EN_KEN | MSD_C_CK<br>C_CK_SD<br>CKEN | MSD_C_CK<br>AC_MD_DET<br>CKEN | MSD_C_CK<br>VOL_PSC<br>CKEN | MSD_C_CK<br>PSC_SPC<br>N_CKE_N | MSD_C_CK<br>CKE_N | AHB_CK_G<br>DMA_CKE_N | reserved2           |                     | reserved2 |                    | reserved2 |                    | reserved2                        |                    | ENABLE_S<br>INGL_E_BU<br>RST |  |
| <b>Type</b>                | RW                              | RW                            | RW                          | RW                            | RW                          | RW                             | RW                | RW                    | RW                  | RW                  |           | RW                 |           | RW                 |                                  | RW                 |                              |  |
| <b>Reset</b>               | 1                               | 1                             | 1                           | 1                             | 1                           | 1                              | 1                 | 1                     | 1                   | 1                   | 1         | 1                  | 1         | 1                  | 1                                | 1                  | 0                            |  |
| <b>Bit</b>                 | 15                              | 14                            | 13                          | 12                            | 11                          | 10                             | 9                 | 8                     | 7                   | 6                   | 5         | 4                  | 3         | 2                  | 1                                | 0                  |                              |  |
| <b>Name</b>                |                                 |                               | BIAS_EXT<br>BIAS_28NM_M     | BIAS_EN1<br>8IO_28NM          | BIAS_TUNE_28NM              |                                |                   | GET_CRC_MAR<br>GIN    | GET_BUSY_MA<br>RGIN | CMD_RSP_TA_CN<br>TR |           | WRDAT_CRCST_A_CNTR |           | WRDAT_CRCST_A_CNTR |                                  | WRDAT_CRCST_A_CNTR |                              |  |
| <b>Type</b>                |                                 |                               | RW                          | RW                            | RW                          |                                |                   | RW                    | RW                  | RW                  |           | RW                 |           | RW                 |                                  | RW                 |                              |  |
| <b>Reset</b>               |                                 |                               | 0                           | 0                             | 0                           | 0                              | 0                 | 0                     | 0                   | 0                   | 0         | 0                  | 1         | 0                  | 0                                | 0                  | 1                            |  |

| <b>Bit(s)</b> | <b>Mnemonic</b>  | <b>Name</b>        | <b>Description</b>                                                             |
|---------------|------------------|--------------------|--------------------------------------------------------------------------------|
| 31            | <b>MSHBFCKEN</b> | MSDC_CK_SHBFF_CKEN | <b>msdc_src_ck clock enable bit for SHBFF</b><br>1'bo: Disable<br>1'b1: Enable |
| 30            | <b>MRCTLCKEN</b> | MSDC_CK_RCTL_CKEN  | <b>msdc_src_ck clock enable bit for RCTL</b>                                   |

|       |                      |                     |                                                                                                                                                                                                                                                                                                                                           |
|-------|----------------------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |                      |                     |                                                                                                                                                                                                                                                                                                                                           |
| 29    | <b>MWCTLCKEN</b>     | MSDC_CK_WCTL_CKEN   | 1'bo: Disable<br>1'b1: Enable<br><b>msdc_src_ck clock enable bit for WCTL</b>                                                                                                                                                                                                                                                             |
| 28    | <b>MSDCKEN</b>       | MSDC_CK_SD_CKEN     | 1'bo: Disable<br>1'b1: Enable<br><b>msdc_src_ck clock enable bit for SD</b>                                                                                                                                                                                                                                                               |
| 27    | <b>MACMDCKEN</b>     | MSDC_CK_ACMD_CKEN   | 1'bo: Disable<br>1'b1: Enable<br><b>msdc_src_ck clock enable bit for ACMD</b>                                                                                                                                                                                                                                                             |
| 26    | <b>MVOLDTCKEN</b>    | MSDC_CK_VOLDET_CKEN | 1'bo: Disable<br>1'b1: Enable<br><b>msdc_src_ck clock enable bit for VOLDET</b>                                                                                                                                                                                                                                                           |
| 25    | <b>MPSCCKEN</b>      | MSDC_CK_PSC_CKEN    | 1'bo: Disable<br>1'b1: Enable<br><b>msdc_src_ck clock enable bit for PSC</b>                                                                                                                                                                                                                                                              |
| 24    | <b>MSPCCKEN</b>      | MSDC_CK_SPC_CKEN    | 1'bo: Disable<br>1'b1: Enable<br><b>msdc_src_ck clock enable bit for SPC</b>                                                                                                                                                                                                                                                              |
| 23    | <b>HGDMACKEN</b>     | AHB_CK_GDMA_CKEN    | 1'bo: Disable<br>1'b1: Enable<br><b>hclk_ck clock enable bit for GDMA</b>                                                                                                                                                                                                                                                                 |
| 22:17 |                      | reserved2           |                                                                                                                                                                                                                                                                                                                                           |
| 16    | <b>SINGLEBURST</b>   | ENABLE_SINGLE_BURST | <b>The AHB bus will not support incr1 burst type in the future. It will only affect the AHB bus MSDC design, but not the AXI bus design</b><br>1'bo:hardware will send incr1 burst type<br>1'b1: hardware will send single burst type instead of incr1 type                                                                               |
| 13    | <b>BIAS28Ro</b>      | BIAS_EXTBIAS_28NM   | <b>28NM BIAS Controller register 0</b>                                                                                                                                                                                                                                                                                                    |
| 12    | <b>BIAS28R1</b>      | BIAS_EN18IO_28NM    | <b>28NM BIAS Controller register 1</b>                                                                                                                                                                                                                                                                                                    |
| 11:8  | <b>BIAS28R2</b>      | BIAS_TUNE_28NM      | <b>28NM BIAS Controller register 2</b>                                                                                                                                                                                                                                                                                                    |
| 7     | <b>GETCRCMARGIN</b>  | GET_CRC_MARGIN      | This will add margin for getting the CRC status when the card response CRC does not match with the 2 cycles (described in the SD specification) starting from the end bit<br>1'bo: 8 cycles are reserved to get the CRC status from write data CRC end bit<br>1'b1: 16 cycles reserved for getting CRC status from write data CRC end bit |
| 6     | <b>GETBUSYMARGIN</b> | GET_BUSY_MARGIN     | <b>This will add margin for the get busy</b>                                                                                                                                                                                                                                                                                              |

|                                                                                                                           |  |  | <b>state of datao</b>                                              |
|---------------------------------------------------------------------------------------------------------------------------|--|--|--------------------------------------------------------------------|
| 5:3 <b>CMDTA</b>                                                                                                          |  |  | 1'bo: 1 cycle reserved for get busy state from SRC status end bit  |
| 2:0 <b>WRTA</b>                                                                                                           |  |  | 1'b1: 3 cycles reserved for get busy state from SRC status end bit |
|                                                                                                                           |  |  | <b>CMD response turn around period</b>                             |
| The turn around cycle = CMD_RSP_TA_CNTR + 2, Only for USH104 mode, this register should be set to 0 in non-UHS104 mode    |  |  |                                                                    |
|                                                                                                                           |  |  | <b>Write data and CRC status turn around period</b>                |
| The turn around cycle = WRDAT_CRCS_TA_CNTR + 2, Only for USH104 mode, this register should be set to 0 in non-UHS104 mode |  |  |                                                                    |

**A10300EC PAD TUNE                                    MSDC Pad Tuning Register                                    00000000**

| Bit   | 31                   | 30 | 29                          | 28                      | 27 | 26                        | 25 | 24 | 23              | 22 | 21                      | 20                      | 19 | 18 | 17 | 16 |
|-------|----------------------|----|-----------------------------|-------------------------|----|---------------------------|----|----|-----------------|----|-------------------------|-------------------------|----|----|----|----|
| Name  | <b>PAD_CLK_TXDLY</b> |    |                             |                         |    | <b>PAD_CMD_RESP_RXDLY</b> |    |    |                 |    | <b>PAD_CMD_RD_RXDLY</b> | <b>PAD_CMD_RXDLY</b>    |    |    |    |    |
| Type  | RW                   |    |                             |                         |    | RW                        |    |    |                 |    | RW                      | RW                      |    |    |    |    |
| Reset | 0                    | 0  | 0                           | 0                       | 0  | 0                         | 0  | 0  | 0               | 0  | 0                       | 0                       | 0  | 0  | 0  | 0  |
| Bit   | 15                   | 14 | 13                          | 12                      | 11 | 10                        | 9  | 8  | 7               | 6  | 5                       | 4                       | 3  | 2  | 1  | 0  |
| Name  |                      |    | <b>PAD_DAT_RD_RXDLY_SEL</b> | <b>PAD_DAT_RD_RXDLY</b> |    |                           |    |    | <b>DELAY_EN</b> |    |                         | <b>PAD_DAT_WR_RXDLY</b> |    |    |    |    |
| Type  |                      |    | RW                          | RW                      |    |                           |    |    | RW              |    |                         | RW                      |    |    |    |    |
| Reset |                      |    | 0                           | 0                       | 0  | 0                         | 0  | 0  | 0               |    |                         | 0                       | 0  | 0  | 0  | 0  |

| Bit(s) | Mnemonic           | Name                        | Description                                                                                                                                            |
|--------|--------------------|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:27  | <b>CLKTDLY</b>     | <b>PAD_CLK_TXDLY</b>        | <b>CLK Pad TX Delay Control</b><br>This register is used to add delay to CLK phase.<br>Total 32 stages                                                 |
| 26:22  | <b>CMDRRDLY</b>    | <b>PAD_CMD_RESP_RXDLY</b>   | <b>CMD Response Internal Delay Line Control</b><br>This register is used to fine-tune response phase latched by MSDC internal clock<br>Total 32 stages |
| 21     | <b>CMDRRDLYSEL</b> | <b>PAD_CMD_RD_RXDLY_SEL</b> | <b>Decide if CMD Response passes through data delay line1 or not</b><br>1'bo: pass<br>1'b1: do not pass                                                |
| 20:16  | <b>CMDRDLY</b>     | <b>PAD_CMD_RXDLY</b>        | <b>CMD Pad RX Delay Line Control</b><br>This register is used to fine-tune CMD pad macro response latch timing<br>Total 32 stages                      |
| 13     | <b>DATRRDLYSEL</b> | <b>PAD_DAT_RD_RXDLY</b>     | <b>Decide if RX data passes through data delay</b>                                                                                                     |

|      |                 | _SEL             | line1 or not                                                                                                                                                    |
|------|-----------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12:8 | <b>DATRRDLY</b> | PAD_DAT_RD_RXDLY | <b>DAT Pad RX Delay Line Control (for MSDC read only)</b><br>This register is used to fine-tune DAT pad macro read data latch timing<br>Total 32 stages         |
| 7    | <b>DELAYEN</b>  | DELAY_EN         | <b>Enable all delay cell toggling when powered on</b><br>1'bo: disable delay cell toggling default<br>1'b1: enable delay cell toggling default                  |
| 4:0  | <b>DATWRDLY</b> | PAD_DAT_WR_RXDLY | <b>Write Data Status Internal Delay Line Control</b><br>This register is used to fine-tune write status phase latched by MSDC internal clock<br>Total 32 stages |

| <b>A10300Fo DAT RD DLYo MSDC Data Delay Line Register 0 00000000</b> |                    |    |    |    |    |    |    |    |    |    |                    |    |    |    |    |    |
|----------------------------------------------------------------------|--------------------|----|----|----|----|----|----|----|----|----|--------------------|----|----|----|----|----|
| <b>Bit</b>                                                           | 31                 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21                 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b>                                                          | <b>DAT0_RD_DLY</b> |    |    |    |    |    |    |    |    |    | <b>DAT1_RD_DLY</b> |    |    |    |    |    |
| <b>Type</b>                                                          | RW                 |    |    |    |    |    |    |    |    |    | RW                 |    |    |    |    |    |
| <b>Reset</b>                                                         | 0 0 0 0 0          |    |    |    |    |    |    |    |    |    | 0 0 0 0 0          |    |    |    |    |    |
| <b>Bit</b>                                                           | 15                 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5                  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>                                                          | <b>DAT2_RD_DLY</b> |    |    |    |    |    |    |    |    |    | <b>DAT3_RD_DLY</b> |    |    |    |    |    |
| <b>Type</b>                                                          | RW                 |    |    |    |    |    |    |    |    |    | RW                 |    |    |    |    |    |
| <b>Reset</b>                                                         | 0 0 0 0 0          |    |    |    |    |    |    |    |    |    | 0 0 0 0 0          |    |    |    |    |    |

| Bit(s) | Mnemonic         | Name        | Description                                                            |
|--------|------------------|-------------|------------------------------------------------------------------------|
| 28:24  | <b>DAT0RDDLY</b> | DAT0_RD_DLY | <b>DAT0 Pad RX Delay Line Control (for MSDC RD)</b><br>Total 32 stages |
| 20:16  | <b>DAT1RDDLY</b> | DAT1_RD_DLY | <b>DAT1 Pad RX Delay Line Control (for MSDC RD)</b><br>Total 32 stages |
| 12:8   | <b>DAT2RDDLY</b> | DAT2_RD_DLY | <b>DAT2 Pad RX Delay Line Control (for MSDC RD)</b><br>Total 32 stages |
| 4:0    | <b>DAT3RDDLY</b> | DAT3_RD_DLY | <b>DAT3 Pad RX Delay Line Control (for MSDC RD)</b><br>Total 32 stages |

| <b>A10300F4 DAT RD DLY1 MSDC Data Delay Line Register 1 00000000</b> |                    |    |    |    |    |    |    |    |    |    |                    |    |    |    |    |    |
|----------------------------------------------------------------------|--------------------|----|----|----|----|----|----|----|----|----|--------------------|----|----|----|----|----|
| <b>Bit</b>                                                           | 31                 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21                 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b>                                                          | <b>DAT4_RD_DLY</b> |    |    |    |    |    |    |    |    |    | <b>DAT5_RD_DLY</b> |    |    |    |    |    |
| <b>Type</b>                                                          | RW                 |    |    |    |    |    |    |    |    |    | RW                 |    |    |    |    |    |
| <b>Reset</b>                                                         | 0 0 0 0 0          |    |    |    |    |    |    |    |    |    | 0 0 0 0 0          |    |    |    |    |    |
| <b>Bit</b>                                                           | 15                 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5                  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>                                                          | <b>DAT6_RD_DLY</b> |    |    |    |    |    |    |    |    |    | <b>DAT7_RD_DLY</b> |    |    |    |    |    |
| <b>Type</b>                                                          | RW                 |    |    |    |    |    |    |    |    |    | RW                 |    |    |    |    |    |

|              |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|--------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| <b>Reset</b> | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|--------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|

| Bit(s) | Mnemonic         | Name        | Description                                                            |
|--------|------------------|-------------|------------------------------------------------------------------------|
| 28:24  | <b>DAT4RDDLY</b> | DAT4_RD_DLY | <b>DAT4 Pad RX Delay Line Control (for MSDC RD)</b><br>Total 32 stages |
| 20:16  | <b>DAT5RDDLY</b> | DAT5_RD_DLY | <b>DAT5 Pad RX Delay Line Control (for MSDC RD)</b><br>Total 32 stages |
| 12:8   | <b>DAT6RDDLY</b> | DAT6_RD_DLY | <b>DAT6 Pad RX Delay Line Control (for MSDC RD)</b><br>Total 32 stages |
| 4:0    | <b>DAT7RDDLY</b> | DAT7_RD_DLY | <b>DAT7 Pad RX Delay Line Control (for MSDC RD)</b><br>Total 32 stages |

**A10300F8 HW DBG SEL MSDC H/W Debug Selection Register 00000000**

| Bit          | 31 | 30                      | 29                 | 28 | 27 | 26 | 25 | 24                 | 23                           | 22                 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|----|-------------------------|--------------------|----|----|----|----|--------------------|------------------------------|--------------------|----|----|----|----|----|----|
| <b>Name</b>  |    | <b>HW_DBG_WRA_P_SEL</b> | <b>HW_DBG0_SEL</b> |    |    |    |    |                    | <b>HW_DBG_WRAP_TYP_E_SEL</b> | <b>HW_DBG1_SEL</b> |    |    |    |    |    |    |
| <b>Type</b>  |    | RW                      | RW                 |    |    |    |    |                    | RW                           | RW                 |    |    |    |    |    |    |
| <b>Reset</b> |    | 0                       | 0                  | 0  | 0  | 0  | 0  | 0                  | 0                            | 0                  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>   | 15 | 14                      | 13                 | 12 | 11 | 10 | 9  | 8                  | 7                            | 6                  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  |    | <b>HW_DBG2_SEL</b>      |                    |    |    |    |    | <b>HW_DBG3_SEL</b> |                              |                    |    |    |    |    |    |    |
| <b>Type</b>  |    | RW                      |                    |    |    |    |    | RW                 |                              |                    |    |    |    |    |    |    |
| <b>Reset</b> |    | 0                       | 0                  | 0  | 0  | 0  | 0  | 0                  | 0                            | 0                  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Mnemonic        | Name                  | Description                                                                                                                                                                                                                            |
|--------|-----------------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30     | <b>DBGWSEL</b>  | HW_DBG_WRAP_SEL       | <b>Hardware debug output selection for wrapper</b><br>0: Select original debug pins<br>1: Select wrapper debug pins                                                                                                                    |
| 29:24  | <b>DBG0SEL</b>  | HW_DBG0_SEL           | <b>Hardware debug output selection</b>                                                                                                                                                                                                 |
| 23:22  | <b>DBGWTSEL</b> | HW_DBG_WRAP_TYP_E_SEL | <b>Hardware debug output selection for wrapper</b><br>2'd0: Select dbg_in20~dbg_in3b = DRAM_DBG<br>2'd1: Select dbg_in20~dbg_in3b = RISC_DBG<br>2'd2: Select dbg_in20~dbg_in3b = AHBM_DBG<br>2'd3: Select dbg_in20~dbg_in3b = AHBS_DBG |
| 21:16  | <b>DBG1SEL</b>  | HW_DBG1_SEL           | <b>Hardware debug output selection</b>                                                                                                                                                                                                 |
| 13:8   | <b>DBG2SEL</b>  | HW_DBG2_SEL           | <b>Hardware debug output selection</b>                                                                                                                                                                                                 |
| 7:0    | <b>DBG3SEL</b>  | HW_DBG3_SEL           | <b>Hardware debug output selection</b>                                                                                                                                                                                                 |

**A1030100 MAIN VER MSDC Main Version Register 20160503**

| Bit             | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>MAIN_VER</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>RO</b>       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>    | 0  | 0  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 1  | 1  | 0  |

|              |                 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------------|-----------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Bit</b>   | 15              | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| <b>Name</b>  | <b>MAIN_VER</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>  | RO              |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Reset</b> | 0               | 0  | 0  | 0  | 0  | 1  | 0 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 |

| Bit(s) | Mnemonic       | Name            | Description         |
|--------|----------------|-----------------|---------------------|
| 31:0   | <b>MAINVER</b> | <b>MAIN_VER</b> | <b>Main Version</b> |

|                 |                |                                  |                     |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-----------------|----------------|----------------------------------|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>A1030104</b> | <b>ECO VER</b> | <b>MSDC ECO Version Register</b> | <b>oooooooooooo</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Bit</b>      | 31             | 30                               | 29                  | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b>     | <b>ECO_VER</b> |                                  |                     |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>     | RO             |                                  |                     |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>    | 0              | 0                                | 0                   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>      | 15             | 14                               | 13                  | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>     | <b>ECO_VER</b> |                                  |                     |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>     | RO             |                                  |                     |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>    | 0              | 0                                | 0                   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Mnemonic      | Name           | Description        |
|--------|---------------|----------------|--------------------|
| 31:0   | <b>ECOVER</b> | <b>ECO_VER</b> | <b>ECO Version</b> |

## 10. I2S0

### 10.1. Overview

I2S0 is placed on AHB bus to support fast data transfers and has APB interface for setting the control register (CR). I2S0 contains CLK CON, I2S OUT, I2S IN, DL FIFO and UL FIFO. The block diagram is shown in Figure 10.1-1.



Figure 10.1-1. I2S block diagram

Keywords: Audio Codec, XPLL, CLKCON, I2S, AHB slave, DMA, UL DL FIFO, I2S0 CR, APB slave, XO (26M only), PLL1, PLL2.

### 10.2. IO interface

- AHB slave interface (refer to AMBA v2.0)
- APB slave interface (refer to AMBA v3.0)
- Maximum internal delay of each interface is 13.3ns. Only supports 16bits per channel.

The I2S mode interface for master mode and slave mode is shown in Table 10.2-1 and Table 10.2-2. The TDM mode interface for master mode and slave mode is shown in Table 10.2-3 and Table 10.2-4.

Table 10.2-1. I2S mode interface – master mode

| PIN name | Direction       | Description                                                                |
|----------|-----------------|----------------------------------------------------------------------------|
| I2S_MCLK | Output          | 26/24.576/22.5792MHz                                                       |
| I2S_BCLK | Master : Output | I2S_FS*32                                                                  |
| I2S_FS   | Master : Output | 11.025, 22.05, 44.1, 88.2, 176.4 kHz<br>8, 12, 16, 24, 32, 48, 96, 192 kHz |

| PIN name | Direction | Description |
|----------|-----------|-------------|
| I2S_TX   | Output    | TX data     |
| I2S_RX   | Input     | RX data     |

**Table 10.2-2. I2S mode interface – slave mode**

| PIN name | Direction     | Description                                                                |
|----------|---------------|----------------------------------------------------------------------------|
| I2S_MCLK | Output        | 26/24.576/22.5792MHz                                                       |
| I2S_BCLK | Slave : Input | I2S_FS*32                                                                  |
| I2S_FS   | Slave : Input | 11.025, 22.05, 44.1, 88.2, 176.4 kHz<br>8, 12, 16, 24, 32, 48, 96, 192 kHz |
| I2S_TX   | Output        | TX data                                                                    |
| I2S_RX   | Input         | RX data                                                                    |

**Table 10.2-3. TDM mode interface – master mode**

| PIN name | Direction       | Description                                                                |
|----------|-----------------|----------------------------------------------------------------------------|
| I2S_MCLK | Output          | 26/24.576/22.5792MHz                                                       |
| I2S_BCLK | Master : Output | I2S_FS*32, I2S_FS*64                                                       |
| I2S_FS   | Master : Output | 11.025, 22.05, 44.1, 88.2, 176.4 kHz<br>8, 12, 16, 24, 32, 48, 96, 192 kHz |
| I2S_TX   | Output          | TX data                                                                    |
| I2S_RX   | Input           | RX data                                                                    |

**Table 10.2-4. TDM mode interface – slave mode**

| PIN name | Direction     | Description                                                                |
|----------|---------------|----------------------------------------------------------------------------|
| I2S_MCLK | Output        | 26/24.576/22.5792MHz                                                       |
| I2S_BCLK | Slave : Input | I2S_FS*32, I2S_FS*64, I2S_FS*128                                           |
| I2S_FS   | Slave : Input | 11.025, 22.05, 44.1, 88.2, 176.4 kHz<br>8, 12, 16, 24, 32, 48, 96, 192 kHz |
| I2S_TX   | Output        | TX data                                                                    |
| I2S_RX   | Input         | RX data                                                                    |

NOTE1: 8 channel TDM doesn't support 192kHz and 176.4kHz

NOTE2: For master mode, I2S\_MCLK frequencies only support relative sample rates listed in Table 10.2-5, I2S\_MCLK from 24.576/22.5792MHz is for high definition (HD) mode.

**Table 10.2-5. Relationship between MCLK and sample rate**

| I2S_MCLK           | Sample Rate                          |
|--------------------|--------------------------------------|
| 26MHz (XO or XPLL) | 8, 12, 16, 24, 32, 48 kHz            |
| 24.576MHz (XPLL)   | 8, 12, 16, 24, 32, 48, 96, 192 kHz   |
| 22.5792MHz (XPLL)  | 11.025, 22.05, 44.1, 88.2, 176.4 kHz |

### 10.3. I2S OUT and I2S IN

I2S OUT and I2S IN support standard I2S protocol and both master/slave mode. The I2S protocol is in Figure 10.3-1. The TDM mode protocol is in Figure 10.3-2, Figure 10.3-3 and Figure 10.3-4.



**Figure 10.3-1. I2S protocol waveform**

If I2S OUT operates in mono mode, R[15:0] will be the same as L[15:0]. If I2S IN operates in mono mode, R[15:0] will not affect I2S IN's output to UL FIFO.

Note: When I2S acts as slave and connects to the external codec, I2S IN and I2S OUT will use the same BCLK/FS from the external codec. Therefore, the sample rate of TX/RX should be the same. However, there is a down rate mode where TX SR could be twice of RX SR. In this mode, RX will receive one duplicate data in every SR cycle and I2S IN will automatically discard the duplicate data and not send it into UL FIFO. Example is shown in Table 10.3-1.

**Table 10.3-1. Down rate example for slave mode**

| Slave Mode     | Input Sample Rate | Output Sample Rate | Mono/Stereo | MCLK (output) | BCLK (input) | LRCLK (input) |
|----------------|-------------------|--------------------|-------------|---------------|--------------|---------------|
| Down Rate Mode | 16b, 24kHz        | 16b, 48kHz         | Both        | 24.576 MHz    | 1.536MHz     | 48kHz         |



**Figure 10.3-2. Sample m of TDM32 with nT delay**

Keywords: I2S\_BCLK, I2S\_FS, I2S\_TX/RX, R\_, L\_



**Figure 10.3-3. Sample m of TDM32 with nT delay and bclk inverse**

Keywords: I2S\_BCLK, I2S\_FS, I2S\_TX/RX, R<sub>\_</sub>, L<sub>\_</sub>



**Figure 10.3-4. Sample m of TDM64 with nT delay**

Keywords: I2S\_BCLK, I2S\_FS, I2S\_TX/RX, R<sub>\_</sub>, L<sub>\_</sub>

## 10.4. DL FIFO and UL FIFO

DL FIFO and UL FIFO are asynchronous FIFOs with depth 8. One side of these asynchronous FIFO is in BUS clock domain and the other is in XPLL or I2S\_BCLK clock domain.

## 10.5. Data format of FIFO

16bits I2S and 16bits TDM data format of FIFO are shown in Table 10.5-1 and Table 10.5-2.

**Table 10.5-1. 16bits I2S data format of FIFO**

|        | Byte 3  | Byte 2 | Byte 1  | Byte 0 |
|--------|---------|--------|---------|--------|
| Stereo | R[15:8] | R[7:0] | L[15:8] | L[7:0] |
| Mono   | 8'b0    | 8'b0   | L[15:8] | L[7:0] |

**Table 10.5-2. 16bits TDM 4 channel data format of FIFO**

|               | Byte 3    | Byte 2    | Byte 1     | Byte 0   |
|---------------|-----------|-----------|------------|----------|
| Channel 0 & 1 | CH1[15:8] | CH1 [7:0] | CHO [15:8] | CHO[7:0] |
|               | Byte 7    | Byte 6    | Byte 5     | Byte 4   |
| Channel 2 & 3 | CH3[15:8] | CH3[7:0]  | CH2[15:8]  | CH2[7:0] |

## 10.6. Programming guide

I2S0 supports two I2S interface modes: 16bits I2S mode and 16bits TDM mode. Before I2S transfer, GPIO should be set to related modes in the software, please refer to the GPIO section in this manual.

DMA should be turned on to prevent FIFO overflow. For the related DMA register map, please refer to the DMA section in this manual. The I2S0 DMA programming guide for PSRAM data input is as follows:

- 1) To turn on the DMA clock:
  - Write: PDN\_CLRDO = 0x1;
- 2) To set DMA CH7 for I2S\_TX:
  - Write: VDMA7\_PGMADDR = 0x10000; //to set start address
  - Write: VDMA7\_COUNT = 0x9C4; //to set transfer threshold
  - Write: VDMA7\_FFSIZE = 0x9C4; //to set transfer length
  - Write: VDMA7\_CON = 0x10200; // [16]: to enable hardware hand shake, [9:8]: to set word size = 2, [4]: to set DIR: 0=peripheral TX
- 3) To set DMA CH8 for I2S\_RX:
  - Write: VDMA8\_PGMADDR = 0x10000; //to set start address
  - Write: VDMA8\_COUNT = 0x9C4; //to set transfer threshold
  - Write: VDMA8\_FFSIZE = 0x9C4; //to set transfer length
  - Write: VDMA8\_CON = 0x10210; // [16]: to enable hardware hand shake, [9:8]: to set word size = 2, [4]: to set DIR: 1=peripheral RX
- 4) To start DMA transfer:
  - Write: VDMA7\_START = 0x8000;
  - Write: VDMA8\_START = 0x8000;
- 5) To use HD mode, please refer to Chapter 12, "I2S0 and I2S1 Audio PLL Settings" to enable XPLL.

### 10.6.1. I2S0 general programming guide

- 1) If XPLL is on, XPLL is 26MHz,
  - Write: I2S\_GLOBAL\_CONTROL= 0x2A0C0028;  
Or if XPLL is 24.576MHz,  
• Write: I2S\_GLOBAL\_CONTROL= 0x000C0028;  
Or if XPLL is 22.5792MHz,  
• Write: I2S\_GLOBAL\_CONTROL= 0x150C0028;  
Or if XO is 26MHz  
• Write: I2S\_GLOBAL\_CONTROL= 0x2A080028;
- 2) If in slave mode,
  - Write: I2S\_GLOBAL\_CONTROL[27:24]=0xF
  - Write: I2S\_GLOBAL\_CONTROL[20]=1;
- 3) If in slave mode, BCLK is inverse to protocol,

- Write: I2S\_GLOBAL\_CONTROL[19]=0
- 4) For data loopback test,
- Write: I2S\_GLOBAL\_CONTROL[31]=1

### 10.6.2. I2S mode

- 1) If in master mode,
  - Write: I2S\_DL\_CONTROL=0x08008009;
  - Write: I2S\_UL\_CONTROL=0x08008009;

Or

- Write: I2S\_DL\_CONTROL=0x0800800D;
- Write: I2S\_UL\_CONTROL=0x0800800D;
- 2) If in down rate mode,
  - Write: I2S\_UL\_CONTROL[16]=1;

### 10.6.3. TDM mode

- 1) If in master mode,

For TDM64 channel 4,

- Write: I2S\_DL\_CONTROL=0x2800A021;
- Write: I2S\_UL\_CONTROL=0x2800A021;
- Write: I2S\_DL\_CONTROL[7]=1;

For TDM64 channel 2,

- Write: I2S\_DL\_CONTROL=0x0800A021;
- Write: I2S\_UL\_CONTROL=0x0800A021;

For TDM128 channel 4,

- Write: I2S\_DL\_CONTROL=0x2800C021;
- Write: I2S\_UL\_CONTROL=0x2800C021;
- Write: I2S\_DL\_CONTROL[7]=1;

For TDM128 channel 2,

- Write: I2S\_DL\_CONTROL=0x0800C021;
- Write: I2S\_UL\_CONTROL=0x0800C021;

For TDM32 channel 2,

- Write: I2S\_DL\_CONTROL=0x08008021;
- Write: I2S\_UL\_CONTROL=0x08008021;

Or if in slave mode,

For TDM64 channel 4,

- Write: I2S\_DL\_CONTROL=0x2800A025;

- Write: I2S\_UL\_CONTROL=0x2800A025;
- Write: I2S\_DL\_CONTROL[7]=1;

For TDM64 channel 2,

- Write: I2S\_DL\_CONTROL=0x0800A025;
- Write: I2S\_UL\_CONTROL=0x0800A025;

For TDM128 channel 4,

- Write: I2S\_DL\_CONTROL=0x2800C025;
- Write: I2S\_UL\_CONTROL=0x2800C025;
- Write: I2S\_DL\_CONTROL[7]=1;

For TDM128 channel 2,

- Write: I2S\_DL\_CONTROL=0x0800C025;
- Write: I2S\_UL\_CONTROL=0x0800C025;

For TDM32 channel 2,

- Write: I2S\_DL\_CONTROL=0x08008025;
  - Write: I2S\_UL\_CONTROL=0x08008025;
- 2) If MSB delays one clock cycle,
- Write: I2S\_DL\_CONTROL[23:17]= 0x2
  - Write: I2S\_UL\_CONTROL[23:17]= 0x2

#### 10.6.4. Set sample rate and enable I2S

- 1) To set sample rate:
  - Write: I2S\_DL\_SR\_EN\_CONTROL\_\_F\_CR\_I2S\_OUT\_SR = 0x0~0x1E; // bit[4]: HD mode
  - Write: I2S\_UL\_SR\_EN\_CONTROL\_\_F\_CR\_I2S\_IN\_SR = 0x0~0x1E; // bit[4]: HD mode
- 2) To enable clock,
  - Write: PDN\_CLRDO = 0x80;
  - Write: I2S\_GLOBAL\_EN\_CONTROL\_\_F\_CR\_PDN\_AUD\_26M = 0;
  - Write: I2S\_UL\_SR\_EN\_CONTROL\_\_F\_CR\_PDN\_I2SIN = 0;
  - Write: I2S\_DL\_SR\_EN\_CONTROL\_\_F\_CR\_PDN\_I2SO = 0;
- 3) To do soft reset before active,
  - Write: I2S\_SOFT\_RESET = 0x1;
  - Write: I2S\_SOFT\_RESET = 0x0;
- 4) To enable FIFO and I2S,
  - Write: I2S\_GLOBAL\_EN\_CONTROL\_\_F\_CR\_UL\_FIFO\_EN = 1;
  - Write: I2S\_GLOBAL\_EN\_CONTROL\_\_F\_CR\_DL\_FIFO\_EN = 1;
  - Write: I2S\_UL\_SR\_EN\_CONTROL\_\_F\_CR\_I2S\_IN\_EN = 1;
  - Write: I2S\_DL\_SR\_EN\_CONTROL\_\_F\_CR\_I2S\_OUT\_EN = 1;

- Write: I2S\_GLOBAL\_EN\_CONTROL\_\_F\_CR\_ENABLE = 1;

5) To read RX data from FIFO,

  - Read = ((UINT32P)(0xA1000100))

6) To write data to TX FIFO

  - Write: ((UINT32P)(0xA1000000)) = write\_data

## 10.7. Register mapping

**Module name: I2So Base address: (+A007000h)**

| Address  | Name                         | Width (bits) | Register Function                          |
|----------|------------------------------|--------------|--------------------------------------------|
| A0070000 | <b>I2S GLOBAL CONTROL</b>    | 32           | AUDIO TOP CONTROL REGISTER                 |
| A0070004 | <b>I2S DL CONTROL</b>        | 32           | DL I2S CONTROL REGISTER                    |
| A0070008 | <b>I2S UL CONTROL</b>        | 32           | UL I2S CONTROL REGISTER                    |
| A007000C | <b>I2S SOFT RESET</b>        | 32           | DLUL SOFT RESET REGISTER                   |
| A0070018 | <b>I2S DL FIFO STATUS</b>    | 32           | DL FIFO CONTROL STATUS REGISTER            |
| A007001C | <b>I2S UL FIFO STATUS</b>    | 32           | UL FIFO CONTROL STATUS REGISTER            |
| A0070030 | <b>I2S GLOBAL EN CONTROL</b> | 32           | AUDIO TOP ENABLE CONTROL REGISTER          |
| A0070034 | <b>I2S DL SR EN CONTROL</b>  | 32           | DL I2S SAMPLE RATE ENABLE CONTROL REGISTER |
| A0070038 | <b>I2S UL SR EN CONTROL</b>  | 32           | UL I2S SAMPLE RATE ENABLE CONTROL REGISTER |
| A0070040 | <b>I2S DL INT CONTROL</b>    | 32           | I2S DL INTERRUPT ENABLE CONTROL REGISTER   |
| A0070044 | <b>I2S UL INT CONTROL</b>    | 32           | I2S UL INTERRUPT ENABLE CONTROL REGISTER   |
| A0070048 | <b>I2S INT ACK CONTROL</b>   | 32           | I2S UL INTERRUPT ENABLE CONTROL REGISTER   |

## Aoo7oooo I2S\_GLOBAL\_C AUDIO TOP CONTROL REGISTER ONTROL

00020028

| Bit   | 31                                  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|-------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Mne   | <u>CR_I2S_GLOBAL_CONTROL[31:16]</u> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                                   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  |
| Bit   | 15                                  | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Mne   | <u>CR_I2S_GLOBAL_CONTROL[15:0]</u>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW                                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                                   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 1  | 0  | 0  | 0  |

## Overview

| Bit(s) | Mnemonic                          | Name                      | Description                                                                                                                                                            |
|--------|-----------------------------------|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | <b>CR_I2S_GLOBAL_C<br/>ONTROL</b> | CR_I2S_GLOBAL CONTR<br>OL | <p>[31] <b>CR_I2S_LOOPBACK</b><br/>I2S out to I2S in loopback</p> <p>o: disable<br/>1: enable</p> <p>[29:28] CR_EXT_MCLK_SEL</p> <p>00 : 24.576M<br/>01 : 22.5792M</p> |

10 : 26M (depend on 26M\_SEL)  
 [27:26] CR\_CK\_OUT\_SEL  
 I2S out clock source selection  
 00 : 24.576M  
 01 : 22.5792M  
 10 : 26M (depend on 26M\_SEL)  
 11 : external bclk in (slave)  
 [25:24] CR\_CK\_IN\_SEL  
 I2S in source selection  
 00 : 24.576M  
 01 : 22.5792M  
 10 : 26M (depend on 26M\_SEL)  
 11 : external bclk in (slave)  
 [21] CR\_EN\_PSEL\_CODEC  
 Reserved  
 [20] CR\_NEG\_CAP\_EN  
 Negative edge capture RX data  
 0: disable  
 1: enable  
 [19] CR\_MCLK\_INV  
 MCLK clock inverse  
 0: disable  
 1: enable  
 [18] CR\_CK\_SEL  
 26M clock source selection  
 0 : XTAL 26M  
 1 : XPLL 26M  
 [17] CR\_CODEC\_26M\_EN  
 cg of internal codec(default on)  
 [14:10] CR\_DBG\_SEL  
 Reserved  
 [9] CR\_DL\_MONO\_DUP  
 When DL\_MONO=1, if right channel send duplicate data.  
 0: right channel send all 0.  
 1: right channel send the same data as the left.  
 [8] CR\_DL\_MONO  
 DL MONO mode  
 0: STEREO  
 1: MONO  
 [7] CR\_DL\_LRSW  
 DL with LR switch  
 0: LR no swap  
 1: LR swap  
 [6] CR\_EXT\_LRSW  
 External codec with LR switch  
 0: LR no swap  
 1: LR swap  
 [5] CR\_EXT\_MODE  
 External codec mode(slave)  
 0: internal codec  
 1: external codec  
 [4] CR\_EXT\_IO\_CK  
 Clock source of external codec mode (slave)  
 0: from i2s\_in  
 1: from i2s\_out  
 [3] CR\_ENGEN\_EN  
 Engen enable (Reserved)

**I2S\_DL\_CONT\_DL\_I2S CONTROL REGISTER****00000008****A0070004****ROL**

| <b>Bit</b>   | 31                              | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|---------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Mne</b>   | <b>CR_I2S_DL_CONTROL[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit          | 15                             | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|--------------|--------------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Mne</b>   | <b>CR_I2S_DL_CONTROL[15:0]</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>  | RW                             |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Reset</b> | 0                              | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 |

## Overview

| Bit(s) | Mnemonic                                               | Name                           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------|--------------------------------------------------------|--------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | <b>CR_I2S_DLCSR_I2S_DL_CONT</b><br><b>_CONTROL ROL</b> | <b>DL I2S control register</b> | <p>[31] LR_SWAP Swap the data of Right and Left channels<br/>0: no swap<br/>1: swap</p> <p>[30:29] CH_PER_S Number of channels in each FS cycle (just used in TDM mode)<br/>00: 2 channels<br/>01: 4 channels</p> <p>[23:17] MSB_OFFSET Delay cycle from rising edge of FS to first channel MSB<br/>o : o cycle<br/>n : n cycles</p> <p>[14:13] BIT_PER_S Number of bits in each FS cycle<br/>00: 32 bits<br/>01: 64 bits<br/>10: 128 bits</p> <p>[7] DL FIFO 2D EQ Mode</p> <p>[5] WSINV WS reverse<br/>0 : no reverse<br/>1 : reverse</p> <p>[4] DIR o : TX</p> <p>[3] FMT Data Format<br/>1 : I2S<br/>o : TDM</p> <p>[2] SRC Master/Slave mode<br/>0 : master<br/>1 : slave</p> <p>[1] WLEN Sample Size<br/>0: 16bits</p> |

## Aoo7ooo8 I2S UL CONTR UL I2S CONTROL REGISTER

00000008

|              |                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|--------------|---------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Bit</b>   | 31                              | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Mne</b>   | <b>CR_I2S_UL_CONTROL[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>   | 15                              | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Mne</b>   | <b>CR_I2S_UL_CONTROL[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 0  |

## Overview

| Bit(s) | Mnemonic                                              | Name                           | Description                                                                                                                                                                                                                                                   |
|--------|-------------------------------------------------------|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | <b>CR_I2S_ULCR_I2S_UL_CONT</b><br><b>_CONTROL ROL</b> | <b>UL I2S control register</b> | <p>[31] LR_SWAP Swap the data of Right and Left channels<br/>           0: no swap<br/>           1: swap</p> <p>[30:29] CH_PER_S Number of channels in each FS cycle (just used in TDM mode)<br/>           00: 2 channels<br/>           01: 4 channels</p> |

[28:24] UPDATE\_WORD Select duration to update FIFO data  
 [23:17] MSB\_OFFSET Delay cycle from rising edge of FS to first channel MSB  
 o : 0 cycle  
 n : n cycles  
 [16] DOWN\_RATE Real sample rate is 1/2 of SR  
 o: real sample rate = SR  
 1: drop 1 sample in each 2 input samples  
 [14:13] BIT\_PER\_S Number of bits in each FS cycle  
 00: 32 bits  
 01: 64 bits  
 10: 128 bits  
 [5] WSINV WS reverse  
 o : no reverse  
 1 : reverse  
 [4] DIR 1 : RX  
 [3] FMT Data Format  
 1: I<sub>2</sub>S  
 0 : TDM  
 [2] SRC Master/Slave mode  
 o : master  
 1 : slave  
 [1] WLEN Sample Size  
 o: 16bits

### A007000C I<sub>2</sub>S\_SOFT\_RESET DLUL SOFT RESET REGISTER

00000000

T

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16           |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0            |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CR_SOFT_RSTB |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW           |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0            |

#### Overview

| Bit(s) | Mnemonic            | Name                                                | Description                                        |
|--------|---------------------|-----------------------------------------------------|----------------------------------------------------|
| 0      | <b>CR_SOFT_RSTB</b> | <b>soft reset audio_top and codec, active high.</b> | To reset, please set this bit to 1 and then set 0. |

### A0070018 I<sub>2</sub>S\_DL\_FIFO\_S DL FIFO CONTROL STATUS REGISTER

00000000

TATUS

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                 |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CR_FIFO_DL_STATUS |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RO                |
| Reset |    |    |    |    |    |    |    |    |    |    | o  | o  | o  | o  | o  | o                 |

#### Overview

| Bit(s) | Mnemonic | Name | Description |
|--------|----------|------|-------------|
|        |          |      |             |

|     |                 |                       |                               |
|-----|-----------------|-----------------------|-------------------------------|
| 5:0 | <b>CR_FIFO_</b> | <b>CR_FIFO_DL_STA</b> | <b>[5] CR_FIFO_DL_W_READY</b> |
|     | <b>DL_STATU</b> | <b>TUS</b>            | <b>[4] CR_FIFO_DL_R_READY</b> |
|     | <b>S</b>        |                       | <b>[3] CR_FIFO_DL_FDLL</b>    |
|     |                 |                       | <b>[2] CR_FIFO_DL_AFDLL</b>   |
|     |                 |                       | <b>[1] CR_FIFO_DL_EMPTY</b>   |
|     |                 |                       | <b>[0] CR_FIFO_DL_AEMPTY</b>  |

A007001C **I2S\_UL\_FIFO\_S** UL FIFO CONTROL STATUS REGISTER  
TATUS

00000000

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24                          | 23 | 22 | 21 | 20 | 19                       | 18                          | 17 | 16 |
|-------|----|----|----|----|----|----|----|-----------------------------|----|----|----|----|--------------------------|-----------------------------|----|----|
| Name  |    |    |    |    |    |    |    |                             |    |    |    |    |                          | <b>CR_FIFO_UL_WFIFO_CNT</b> |    |    |
| Type  |    |    |    |    |    |    |    |                             |    |    |    |    | RO                       |                             |    |    |
| Reset |    |    |    |    |    |    |    |                             |    |    |    |    | 0                        | 0                           | 0  | 0  |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8                           | 7  | 6  | 5  | 4  | 3                        | 2                           | 1  | 0  |
| Name  |    |    |    |    |    |    |    | <b>CR_FIFO_UL_RFIFO_CNT</b> |    |    |    |    | <b>CR_FIFO_UL_STATUS</b> |                             |    |    |
| Type  |    |    |    |    |    |    |    | RO                          |    |    |    |    | RO                       |                             |    |    |
| Reset |    |    |    |    |    |    |    | 0                           | 0  | 0  | 0  |    | 0                        | 0                           | 0  | 0  |

## Overview

| Bit(s) | Mnemonic        | Name                   | Description                   |
|--------|-----------------|------------------------|-------------------------------|
| 19:16  | <b>CR_FIFO_</b> | <b>CR_FIFO_UL_WFI</b>  | <b>Reserved</b>               |
|        | <b>UL_WFIFO</b> | <b>FO_CNT</b>          |                               |
|        | <b>_CNT</b>     |                        |                               |
| 11:8   | <b>CR_FIFO_</b> | <b>CR_FIFO_UL_RFIF</b> | <b>Reserved</b>               |
|        | <b>UL_RFIFO</b> | <b>O_CNT</b>           |                               |
|        | <b>_CNT</b>     |                        |                               |
| 5:0    | <b>CR_FIFO_</b> | <b>CR_FIFO_UL_STA</b>  | <b>[5] CR_FIFO_UL_W_READY</b> |
|        | <b>UL_STATU</b> | <b>TUS</b>             | <b>[4] CR_FIFO_UL_R_READY</b> |
|        | <b>S</b>        |                        | <b>[3] CR_FIFO_UL_FULL</b>    |
|        |                 |                        | <b>[2] CR_FIFO_UL_AFULL</b>   |
|        |                 |                        | <b>[1] CR_FIFO_UL_EMPTY</b>   |
|        |                 |                        | <b>[0] CR_FIFO_UL_AEMPTY</b>  |

A0070030 **I2S\_GLOBAL\_E** AUDIO TOP ENABLE CONTROL REGISTER  
N CONTROL

01000000

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24           | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16           |
|-------|----|----|----|----|----|----|----|--------------|----|----|----|----|----|----|----|--------------|
| Name  |    |    |    |    |    |    |    | <b>CR_P</b>  |    |    |    |    |    |    |    | <b>CR_U</b>  |
| Type  |    |    |    |    |    |    |    | <b>DN_A</b>  |    |    |    |    |    |    |    | <b>L_FIF</b> |
| Reset |    |    |    |    |    |    |    | <b>UD_2</b>  |    |    |    |    |    |    |    | <b>O_EN</b>  |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8            | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0            |
| Name  |    |    |    |    |    |    |    | <b>CR_D</b>  |    |    |    |    |    |    |    | <b>CR_E</b>  |
| Type  |    |    |    |    |    |    |    | <b>L_FIF</b> |    |    |    |    |    |    |    | <b>NABL</b>  |
| Reset |    |    |    |    |    |    |    | <b>O_EN</b>  |    |    |    |    |    |    |    | <b>E</b>     |
| Bit   |    |    |    |    |    |    |    | RW           |    |    |    |    |    |    |    | RW           |
|       |    |    |    |    |    |    |    | 1            |    |    |    |    |    |    |    | 0            |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8            | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0            |
| Name  |    |    |    |    |    |    |    | <b>CR_D</b>  |    |    |    |    |    |    |    | <b>CR_E</b>  |
| Type  |    |    |    |    |    |    |    | <b>L_FIF</b> |    |    |    |    |    |    |    | <b>NABL</b>  |
| Reset |    |    |    |    |    |    |    | <b>O_EN</b>  |    |    |    |    |    |    |    | <b>E</b>     |
| Bit   |    |    |    |    |    |    |    | RW           |    |    |    |    |    |    |    | RW           |
|       |    |    |    |    |    |    |    | 0            |    |    |    |    |    |    |    | 0            |

## Overview

| Bit(s) | Mnemonic        | Name                 | Description      |
|--------|-----------------|----------------------|------------------|
| 24     | <b>CR_PDN_A</b> | <b>CR_PDN_AUD_26</b> | <b>0: Normal</b> |
|        | <b>UD_26M</b>   | <b>M</b>             | 1: Power down    |

|    |                                    |                                                    |
|----|------------------------------------|----------------------------------------------------|
| 16 | <b>CR_UL_FIFCR_UL_FIFO_EN_O_EN</b> | <b>DL_FIFO enable</b><br>0: disable<br>1: enable   |
| 8  | <b>CR_DL_FIFCR_DL_FIFO_EN_O_EN</b> | <b>DL_FIFO enable</b><br>0: disable<br>1: enable   |
| 0  | <b>CR_ENABLE CR_ENABLE_E</b>       | <b>Audio top enable</b><br>0: disable<br>1: enable |

A0070034 I2S\_DL\_SR\_EN DL I2S SAMPLE RATE ENABLE CONTROL 00010000  
CONTROL REGISTER

| Bit          | 31 | 30 | 29 | 28                   | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                   |
|--------------|----|----|----|----------------------|----|----|----|----|----|----|----|----|----|----|----|----------------------|
| <b>Name</b>  |    |    |    |                      |    |    |    |    |    |    |    |    |    |    |    | <b>CR_PDN_I2SO</b>   |
| <b>Type</b>  |    |    |    |                      |    |    |    |    |    |    |    |    |    |    |    | RW                   |
| <b>Reset</b> |    |    |    |                      |    |    |    |    |    |    |    |    |    |    |    | 1                    |
| Bit          | 15 | 14 | 13 | 12                   | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                    |
| <b>Name</b>  |    |    |    | <b>CR_I2S_OUT_SR</b> |    |    |    |    |    |    |    |    |    |    |    | <b>CR_I2S_OUT_SR</b> |
| <b>Type</b>  |    |    |    | RW                   |    |    |    |    |    |    |    |    |    |    |    | RW                   |
| <b>Reset</b> |    |    |    | 0                    | 0  | 0  | 0  | 0  |    |    |    |    |    |    |    | 0                    |

## Overview

| Bit(s) | Mnemonic           | Name                 | Description                                                                                                                                                                                                                                                                                                                  |
|--------|--------------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16     | <b>CR_PDN_I2SO</b> | <b>CR_PDN_I2SO</b>   | <b>o: Normal</b><br>1: Power down                                                                                                                                                                                                                                                                                            |
| 12:8   | <b>CR_I2S_O</b>    | <b>CR_I2S_OUT_SR</b> | <b>[11:8]I2S mode select:</b><br>0000b: 8kHz<br>0001b: 11.025kHz<br>0010b: 12kHz<br>0100b: 16kHz<br>0101b: 22.05kHz<br>0110b: 24kHz<br>1000b: 32kHz<br>1001b: 44.1kHz<br>1010b: 48kHz<br>1011b: 88.2kHz<br>1100b: 96kHz<br>1101b: 176.4kHz<br>1110b: 192kHz<br>0011b: 384kHz<br>[12] <b>hd_en</b><br>0: disable<br>1: enable |
| 0      | <b>CR_I2S_O</b>    | <b>CR_I2S_OUT_EN</b> | <b>I2S out enable</b><br>0: disable<br>1: enable                                                                                                                                                                                                                                                                             |

A0070038 I2S\_UL\_SR\_EN UL I2S SAMPLE RATE ENABLE CONTROL 00010000  
CONTROL REGISTER

| Bit         | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16              |
|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|
| <b>Name</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>CR_PDN_I</b> |

|       |    |    |    |    |              |    |   |   |   |   |   |   |   |             |
|-------|----|----|----|----|--------------|----|---|---|---|---|---|---|---|-------------|
| Type  |    |    |    |    |              |    |   |   |   |   |   |   |   | <b>2SIN</b> |
| Reset |    |    |    |    |              |    |   |   |   |   |   |   |   | RW          |
| Bit   | 15 | 14 | 13 | 12 | 11           | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 1           |
| Name  |    |    |    |    | CR_I2S_IN_SR |    |   |   |   |   |   |   |   | 0           |
| Type  |    |    |    |    | RW           |    |   |   |   |   |   |   |   | RW          |
| Reset |    |    |    |    | o            | o  | o | o | o |   |   |   |   | o           |

## Overview

| Bit(s) | Mnemonic         | Name                | Description                                                                                                                                                                                                                                                                                                                  |
|--------|------------------|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16     | <b>CR_PDN_I</b>  | CR_PDN_I2SIN        | <b>o: Normal</b><br>1: Power down                                                                                                                                                                                                                                                                                            |
| 12:8   | <b>CR_I2S_IN</b> | <b>CR_I2S_IN_SR</b> | <b>[11:8]I2S mode select:</b><br>0000b: 8kHz<br>0001b: 11.025kHz<br>0010b: 12kHz<br>0100b: 16kHz<br>0101b: 22.05kHz<br>0110b: 24kHz<br>1000b: 32kHz<br>1001b: 44.1kHz<br>1010b: 48kHz<br>1011b: 88.2kHz<br>1100b: 96kHz<br>1101b: 176.4kHz<br>1110b: 192kHz<br>0011b: 384kHz<br>[12] <b>hd_en</b><br>o: disable<br>1: enable |
| o      | <b>CR_I2S_IN</b> | <b>CR_I2S_IN_EN</b> | <b>I2S out enable</b><br>o: disable<br>1: enable                                                                                                                                                                                                                                                                             |

A0070040 I2S\_DL\_INT\_CO I2S DL INTERRUPT ENABLE CONTROL REGISTER 00000000  
NTROL

|       |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |    |                    |
|-------|----|----|----|----|----|----|----|-------------------|----|----|----|----|----|----|----|--------------------|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24                | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                 |
| Name  |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |    |                    |
| Type  |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |    |                    |
| Reset |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |    |                    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8                 | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                  |
| Name  |    |    |    |    |    |    |    | CR_DL_IN_TSTS_INT |    |    |    |    |    |    |    | CR_DL_CO_NTRL_ITEN |
| Type  |    |    |    |    |    |    |    | RO                |    |    |    |    |    |    |    | RW                 |
| Reset |    |    |    |    |    |    |    | o                 |    |    |    |    |    |    |    | o                  |

## Overview

| Bit(s) | Mnemonic        | Name                            | Description |
|--------|-----------------|---------------------------------|-------------|
| 8      | <b>CR_DL_IN</b> | <b>CR_DL_INTSTS_IN_TSTS_INT</b> |             |
| o      | <b>CR_DL_CO</b> | <b>CR_DL_CONTRL_I_NTRL_ITEN</b> |             |

## N

Aoo70044 I2S\_UL\_INT\_CO I2S UL INTERRUPT ENABLE CONTROL REGISTER 00000000  
NTROL

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24                                     | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                                           |
|-------|----|----|----|----|----|----|----|----------------------------------------|----|----|----|----|----|----|----|----------------------------------------------|
| Name  |    |    |    |    |    |    |    |                                        |    |    |    |    |    |    |    |                                              |
| Type  |    |    |    |    |    |    |    |                                        |    |    |    |    |    |    |    |                                              |
| Reset |    |    |    |    |    |    |    |                                        |    |    |    |    |    |    |    |                                              |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8                                      | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                                            |
| Name  |    |    |    |    |    |    |    | <b>CR_U<br/>L_IN<br/>TSTS<br/>_INT</b> |    |    |    |    |    |    |    | <b>CR_U<br/>L_CO<br/>NTRL<br/>_ITE<br/>N</b> |
| Type  |    |    |    |    |    |    |    | <b>RO</b>                              |    |    |    |    |    |    |    | <b>RW</b>                                    |
| Reset |    |    |    |    |    |    |    | 0                                      |    |    |    |    |    |    |    | 0                                            |

Overview

| Bit(s) | Mnemonic        | Name            | Description |
|--------|-----------------|-----------------|-------------|
| 8      | <b>CR_UL_IN</b> | CR_UL_INTSTS_IN |             |
|        | <b>TSTS_INT</b> | T               |             |
| 0      | <b>CR_UL_CO</b> | CR_UL_CONTRL_I  |             |
|        | <b>NTRL_ITE</b> | TEN             |             |
|        | <b>N</b>        |                 |             |

Aoo70048 I2S\_INT\_ACK\_C I2S UL INTERRUPT ENABLE CONTROL REGISTER 00000000  
ONTROL

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24                                    | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                                    |
|-------|----|----|----|----|----|----|----|---------------------------------------|----|----|----|----|----|----|----|---------------------------------------|
| Name  |    |    |    |    |    |    |    |                                       |    |    |    |    |    |    |    |                                       |
| Type  |    |    |    |    |    |    |    |                                       |    |    |    |    |    |    |    |                                       |
| Reset |    |    |    |    |    |    |    |                                       |    |    |    |    |    |    |    |                                       |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8                                     | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                                     |
| Name  |    |    |    |    |    |    |    | <b>CR_D<br/>L_AC<br/>KINT<br/>ACK</b> |    |    |    |    |    |    |    | <b>CR_U<br/>L_AC<br/>KINT<br/>ACK</b> |
| Type  |    |    |    |    |    |    |    | <b>RW</b>                             |    |    |    |    |    |    |    | <b>RW</b>                             |
| Reset |    |    |    |    |    |    |    | 0                                     |    |    |    |    |    |    |    | 0                                     |

Overview

| Bit(s) | Mnemonic        | Name           | Description |
|--------|-----------------|----------------|-------------|
| 8      | <b>CR_DL_AC</b> | CR_DL_ACKINT_A |             |
|        | <b>KINT_ACK</b> | CK             |             |
| 0      | <b>CR_UL_AC</b> | CR_UL_ACKINT_A |             |
|        | <b>KINT_ACK</b> | CK             |             |

## 11. I2S1

### 11.1. Overview

I2S1 is placed on AHB bus to support fast data transfers and has APB interface for setting the control register (CR).

I2S1 contains CLK CON, I2S OUT, I2S IN, DL FIFO and UL FIFO. The block diagram is shown in Figure 11.1-1.



Figure 11.1-1. I2S block diagram

Keywords: Audio Codec, XPLL, CLKCON, I2S, AHB slave, DMA, UL DL FIFO, I2S1 CR, APB slave, XO (26M only), PLL1, PLL2.

### 11.2. IO interface

- AHB slave interface (refer to AMBA v2.0)
- APB slave interface (refer to AMBA v3.0)
- Maximum internal delay of each interface is 13.3ns. Only supports 16bits per channel.

The I2S mode interface for master mode and slave mode is shown in Table 11.2-1 and Table 11.2-2.

Note, when using I2S RX master and the I2S\_FS pin is at 176.4kHz or 192kHz, the output data delay of the relative I2S TX slave codec should be shorter than 19ns.

Table 11.2-1. I2S mode interface – master mode

| PIN name | Direction       | Description          |
|----------|-----------------|----------------------|
| I2S_MCLK | Output          | 26/24.576/22.5792MHz |
| I2S_BCLK | Master : Output | I2S_FS*32, I2S_FS*64 |

| PIN name | Direction       | Description                                                                |
|----------|-----------------|----------------------------------------------------------------------------|
| I2S_FS   | Master : Output | 11.025, 22.05, 44.1, 88.2, 176.4 kHz<br>8, 12, 16, 24, 32, 48, 96, 192 kHz |
| I2S_TX   | Output          | TX data                                                                    |
| I2S_RX   | Input           | RX data                                                                    |

*Table 11.2-2. I2S mode interface – slave mode*

| PIN name | Direction     | Description                                                                |
|----------|---------------|----------------------------------------------------------------------------|
| I2S_MCLK | Output        | 26/24.576/22.5792MHz                                                       |
| I2S_BCLK | Slave : Input | I2S_FS*32, I2S_FS*64                                                       |
| I2S_FS   | Slave : Input | 11.025, 22.05, 44.1, 88.2, 176.4 kHz<br>8, 12, 16, 24, 32, 48, 96, 192 kHz |
| I2S_TX   | Output        | TX data                                                                    |
| I2S_RX   | Input         | RX data                                                                    |

Note, for master mode, I2S\_MCLK frequencies only support relative sample rates listed in Table 11.2-3, I2S\_MCLK from 24.576 or 22.5792MHz is for high definition (HD) mode.

*Table 11.2-3. Relationship between MCLK and sample rate*

| I2S_MCLK           | Sample Rate                          |
|--------------------|--------------------------------------|
| 26MHz (XO or XPLL) | 8, 12, 16, 24, 32, 48 kHz            |
| 24.576MHz (XPLL)   | 8, 12, 16, 24, 32, 48, 96, 192 kHz   |
| 22.5792MHz (XPLL)  | 11.025, 22.05, 44.1, 88.2, 176.4 kHz |

### 11.3. I2S OUT and I2S IN

I2S OUT & I2S IN support standard I2S protocol and both master/slave mode. The 16bits and 24bits I2S protocol is shown in Figure 11.3-1.

**I2S 16bit word length****I2S 24bit word length in 32bit channel length****Figure 11.3-1. I2S protocol waveform**

Keywords: I2S\_BCLK, I2S\_FS, I2S\_TX/RX

If the 16bits I2S OUT operates in mono mode, R[15:0] will be the same as L[15:0]. If I2S IN operates in mono mode, R[15:0] will not affect I2S IN's output to UL FIFO. Operation for 24bits I2S is also the same.

Note: When I2S acts as slave and connects to the external codec, I2S IN and I2S OUT will use the same BCLK/FS from the external codec. Therefore, the sample rate of TX/RX should be the same.

## 11.4. DL FIFO and UL FIFO

DL FIFO & UL FIFO are asynchronous FIFO with depth 8. One side of these asynchronous FIFO is in BUS clock domain and the other is in XPLL or I2S\_BCLK clock domain.

## 11.5. Data format of FIFO

16bits I2S and 24bits I2S data format of FIFO are shown in Table 11.5-1 and Table 11.5-2.

**Table 11.5-1. 16bits I2S data format of FIFO**

|        | <b>Byte 3</b> | <b>Byte 2</b> | <b>Byte 1</b> | <b>Byte 0</b> |
|--------|---------------|---------------|---------------|---------------|
| Stereo | R[15:8]       | R[7:0]        | L[15:8]       | L[7:0]        |
| Mono   | 8'b0          | 8'b0          | L[15:8]       | L[7:0]        |

**Table 11.5-2. 24bits I2S data format of FIFO**

|               | <b>Byte 3</b> | <b>Byte 2</b> | <b>Byte 1</b> | <b>Byte 0</b> |
|---------------|---------------|---------------|---------------|---------------|
| Left Channel  | L0[23:16]     | L0[15:8]      | L0[7:0]       | 8'b0          |
|               | <b>Byte 7</b> | <b>Byte 6</b> | <b>Byte 5</b> | <b>Byte 4</b> |
| Right Channel | R0[23:16]     | R0[15:8]      | R0[7:0]       | 8'b0          |

## 11.6. Programming guide

I2S1 supports two I2S interface modes: 16bits I2S Mode and 24bits I2S Mode. Before I2S transfer, GPIO should be set to related modes in the software, please refer to the GPIO section in this manual.

DMA should be turned on to prevent FIFO overflow. For the related DMA register map, please refer to the DMA section in this manual. The I2S1 DMA programming guide for PSRAM data input is as follows:

To turn on DMA clock:

- Write: PDN\_CLRDO = 0x1;

To set DMA CH7 for I2S\_TX:

- Write: VDMA9\_PGMADDR = 0x10000; //to set start address
- Write: VDMA9\_COUNT = 0x9C4; //to set transfer threshold
- Write: VDMA9\_FFSIZE = 0x9C4; //to set transfer length
- Write: VDMA9\_CON = 0x10200; // [16]: to enable hardware hand shake, [9:8]: to set word size = 2, [4]: to set DIR: 0=peripheral TX

To set DMA CH8 for I2S\_RX:

- Write: VDMA10\_PGMADDR = 0x10000; //to set start address
- Write: VDMA10\_COUNT = 0x9C4; //to set transfer threshold
- Write: VDMA10\_FFSIZE = 0x9C4; //to set transfer length
- Write: VDMA10\_CON = 0x10210; // [16]: to enable hardware hand shake, [9:8]: to set word size = 2, [4]: to set DIR: 1=peripheral RX

To start DMA transfer:

- Write: VDMA9\_START = 0x8000;
- Write: VDMA10\_START = 0x8000;

To use HD mode, please refer to Chapter 12, “I2S0 and I2S1 Audio PLL Settings” to enable XPLL.

### 11.6.1. I2S1 general programming guide

- 1) Select 26M source, if XPLL is on,
- Write: I2S1\_GLOBAL\_CONTROL= 0x40028;
- 2) Or XO is 26MHz
- Write: I2S1\_GLOBAL\_CONTROL= 0x00028;
- 3) For data loopback test,

- Write: I2S1\_GLOBAL\_CONTROL[31]=1
- 4) Select MCLK source I2S1\_GLOBAL\_CONTROL[29:28]
  - For 24.576MHz : 00
  - 22.5792MHz : 01
  - 26 MHz: 10

### 11.6.2. 16bits I2S mode

- 1) If in master mode,
- Write: I2S1\_DL\_CONTROL=0x20009;
- Write: I2S1\_UL\_CONTROL=0x28009;

Or

- Write: I2S1\_DL\_CONTROL=0x2000D;
- Write: I2S1\_UL\_CONTROL=0x2800D;

### 11.6.3. 24bits I2S mode

- 1) If in master mode,
- Write: I2S1\_DL\_CONTROL=0x6008B;
- Write: I2S1\_UL\_CONTROL=0x6800B;

Or

- Write: I2S1\_DL\_CONTROL=0x6008F;
- Write: I2S1\_UL\_CONTROL=0x6800F;

### 11.6.4. Set sample rate and enable I2S

To set sample rate:

- Write: I2S1\_DL\_SR\_EN\_CONTROL\_\_F\_CR\_I2S1\_OUT\_SR = 0x0~0x1E; // bit[4]: HD mode
- Write: I2S1\_UL\_SR\_EN\_CONTROL\_\_F\_CR\_I2S1\_IN\_SR = 0x0~0x1E; // bit[4]: HD mode

To enable clock,

- Write: PDN\_CLRDO = 0x10;
- Write: I2S1\_GLOBAL\_EN\_CONTROL\_\_F\_CR\_PDN\_AUD\_26M = 0;
- Write: I2S1\_UL\_SR\_EN\_CONTROL\_\_F\_CR\_PDN\_I2SIN1 = 0;
- Write: I2S1\_DL\_SR\_EN\_CONTROL\_\_F\_CR\_PDN\_I2SO1= 0;

To do soft reset before active,

- Write: I2S1\_SOFT\_RESET = 0x1;
- Write: I2S1\_SOFT\_RESET = 0x0;

To enable FIFO and I2S,

- Write: I2S1\_GLOBAL\_EN\_CONTROL\_\_F\_CR\_I2S1\_UL\_FIFO\_EN = 1;

- Write: I2S1\_GLOBAL\_EN\_CONTROL\_\_F\_CR\_I2S1\_DL\_FIFO\_EN = 1;
- Write: I2S1\_UL\_SR\_EN\_CONTROL\_\_F\_CR\_I2S1\_IN\_EN = 1;
- Write: I2S1\_DL\_SR\_EN\_CONTROL\_\_F\_CR\_I2S1\_OUT\_EN = 1;
- Write: I2S1\_GLOBAL\_EN\_CONTROL\_\_F\_CR\_I2S1\_ENABLE = 1;

To read RX data from FIFO,

- Read = ((UINT32P)(0xA1000300))

To write data to TX FIFO,

- Write: ((UINT32P)(0xA1000200)) = write\_data

## 11.7. Register mapping

Module name: I2S1 Base address: (+A0080000h)

| Address  | Name                               | Width (bits) | Register Function                                 |
|----------|------------------------------------|--------------|---------------------------------------------------|
| A0080000 | <u>I2S1 GLOBAL C<br/>ONTROL</u>    | 32           | <b>AUDIO TOP CONTROL REGISTER</b>                 |
| A0080004 | <u>I2S1 DL CONTR<br/>OL</u>        | 32           | <b>DL I2S CONTROL REGISTER</b>                    |
| A0080008 | <u>I2S1 UL CONTR<br/>OL</u>        | 32           | <b>UL I2S CONTROL REGISTER</b><br>000             |
| A008000C | <u>I2S1 SOFT RESE<br/>T</u>        | 32           | <b>DLUL SOFT RESET REGISTER</b>                   |
| A0080010 | <u>I2S1 DL FIFO</u>                | 32           | <b>DL FIFO CONTROL REGISTER</b>                   |
| A0080014 | <u>I2S1 UL FIFO</u>                | 32           | <b>UL FIFO CONTROL REGISTER</b>                   |
| A0080018 | <u>I2S1 DL FIFO S<br/>TATUS</u>    | 32           | <b>DL FIFO CONTROL STATUS REGISTER</b>            |
| A008001C | <u>I2S1 UL FIFO S<br/>TATUS</u>    | 32           | <b>UL FIFO CONTROL STATUS REGISTER</b>            |
| A0080020 | <u>I2S1 SCAN RSV</u>               | 32           | <b>SCAN RESERVED REGISTER</b>                     |
| A0080030 | <u>I2S1 GLOBAL E<br/>N CONTROL</u> | 32           | <b>AUDIO TOP ENABLE CONTROL REGISTER</b>          |
| A0080034 | <u>I2S1 DL SR EN<br/>CONTROL</u>   | 32           | <b>DL I2S SAMPLE RATE ENABLE CONTROL REGISTER</b> |
| A0080038 | <u>I2S1 UL SR EN<br/>CONTROL</u>   | 32           | <b>UL I2S SAMPLE RATE ENABLE CONTROL REGISTER</b> |
| A008003C | <u>I2S MONITOR</u>                 | 32           | <b>I2S_MONITOR</b>                                |
| A0080040 | <u>I2S1 DL INT CO<br/>NTROL</u>    | 32           | <b>I2S DL INTERRUPT ENABLE CONTROL REGISTER</b>   |
| A0080044 | <u>I2S1 UL INT CO<br/>NTROL</u>    | 32           | <b>I2S UL INTERRUPT ENABLE CONTROL REGISTER</b>   |
| A0080048 | <u>I2S1 INT ACK C<br/>ONTROL</u>   | 32           | <b>I2S UL INTERRUPT ENABLE CONTROL REGISTER</b>   |

| A008000 | <u>I2S1 GLOBA<br/>L CONTROL</u>      | AUDIO TOP CONTROL REGISTER | 00020028 |
|---------|--------------------------------------|----------------------------|----------|
| Bit     | 31                                   | 30                         | 29       |
| Mne     | 28                                   | 27                         | 26       |
| Type    | 25                                   | 24                         | 23       |
|         | 22                                   | 21                         | 20       |
|         | 19                                   | 18                         | 17       |
|         | 16                                   |                            |          |
|         | <b>CR_I2S1_GLOBAL_CONTROL[31:16]</b> |                            |          |
|         | RW                                   |                            |          |

**Aoo8000 4 I2S1 GLOBA  
L CONTROL**
**AUDIO TOP CONTROL REGISTER****00020028**

|                                         |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-----------------------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Reset</b>                            | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 0 |   |
| <b>Bit</b>                              | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| <b>Mne</b> CR_I2S1_GLOBAL_CONTROL[15:0] |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b> RW                          |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Reset</b>                            | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 0 |   |

**Overview**

| <b>Bit(s)</b> | <b>Mnemonic</b>                   | <b>Name</b>              | <b>Description</b>                                         |
|---------------|-----------------------------------|--------------------------|------------------------------------------------------------|
| 31:0          | CR_I2S1_G CR_I2S1_GLOBAL_CO NTROL | [31] CR_I2S_LOOPBACK_DAT | I2S out to I2S in data loopback<br>o: disable<br>1: enable |

[29:28] CR\_EXT\_MCLK\_SEL  
oob : 24.576MHz  
oib : 22.5792MHz  
10b : 26MHz

[27] CR\_I2S\_LOOPBACK  
I2S in/out clk, ws loopback  
o: disable  
1: enable

[18] CR\_CK\_SEL  
26M clock source selection  
0 : XTAL 26M  
1 : XPLL 26M

[17] CR\_CODEC\_26M\_EN  
cg of internal codec (default on)

[14:10] CR\_DBG\_SEL

[9] CR\_DL\_MONO\_DUP  
When DL\_MONO=1, if right channel sends duplicate data.  
o: right channel sends all o.  
1: right channel sends the same data as the left.

[8] CR\_DL\_MONO  
DL MONO mode  
o: STEREO  
1: MONO

[5] CR\_EXT\_MODE  
External codec mode (slave)  
o: internal codec  
1: external codec

[4] CR\_EXT\_IO\_CK  
Clock source of external codec mode (slave)  
o: from i2s\_in  
1: from i2s\_out

[3] CR\_ENGEN\_EN  
Engen enable (reserved)

**Aoo8000 4 I2S1 DL CO NTROL**
**DL I2S CONTROL REGISTER****00000000**

|                                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|--------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Bit</b>                           | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Mne</b> CR_I2S1_DL_CONTROL[31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b> RW                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b> CR_I2S1_DL_CONTROL[15:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b> RW                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**A008000    I2S1\_DL\_CO  
4            NTROL**
**DL I2S CONTROL REGISTER****oooooooooooo**

|              |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|--------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| <b>Reset</b> | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|--------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|

**Overview**

| <b>Bit(s)</b> | <b>Mnemonic</b>     | <b>Name</b>         | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                    |
|---------------|---------------------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0          | CR_I2S1_DL_CON_TROL | CR_I2S1_DL_CO_NTROL | <p>[30] I2S_soft_reset</p> <p>[27] i2s_in_ck_inv</p> <p>[26] i2s_in_ws_inv</p> <p>[18] i2s out 24bits FIFO mode</p> <p>[17] i2s in out couple mode</p> <p>[7] DL FIFO 2D EQ Mode</p> <p>[5] I2S ws invert</p> <p>[3] I2S FMT</p> <p>0: EIAJ<br/>1: I2S</p> <p>[2] I2S slave mode sel</p> <p>0: master mode<br/>1: slave mode</p> <p>[1] I2S WLEN</p> <p>0: 16 bits<br/>1: 32 bits</p> |

**A008000    I2S1\_UL\_CO  
8            NTROL**
**UL I2S CONTROL REGISTER****ooooooooo8**

|              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Bit</b>   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Mne</b>   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Mne</b>   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**Overview****ooo**

| <b>Bit(s)</b> | <b>Mnemonic</b>                     | <b>Name</b>         | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------------|-------------------------------------|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0          | CR_I2S1_U CR_I2S1_UL_CONT_L_CONTROL | [30] I2S_soft_reset | <p>[27] i2s_in_ck_inv</p> <p>[26] i2s_in_ws_inv</p> <p>[18] i2s in 24bits FIFO mode</p> <p>[17] i2s in out couple mode</p> <p>[15] low fill zero (when the lrck 32 cycle number and the 24/16 bit is valid, the low 16/24bit is zero)</p> <p>0:high bit fill zero (32)<br/>1:low bit fill zero (32)</p> <p>[5] I2S ws invert</p> <p>[3] I2S FMT</p> <p>0: EIAJ (right adjust)<br/>1: I2S</p> <p>[2] I2S slave mode select</p> <p>0: master mode<br/>1: slave mode</p> <p>[1] I2S WLEN</p> <p>0: 16 bits<br/>1: 32 bits</p> |

**Aoo8000 I2S1\_SOFT  
C RESET**
**DLUL SOFT RESET REGISTER****00000000**

| <b>Bit</b>   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16              |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0               |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CR_I2S1_SOFT_RS |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW              |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0               |

**Overview**

| <b>Bit(s)</b> | <b>Mnemonic</b>                          | <b>Name</b> | <b>Description</b>                                                                                     |
|---------------|------------------------------------------|-------------|--------------------------------------------------------------------------------------------------------|
| 0             | CR_I2S1_S CR_I2S1_SOFT_RS<br>OFT_RSTB TB |             | soft reset audio_top and codec, active high.<br>To reset, please write this bit to 1 and then write 0. |

**Aoo80010 I2S1\_DL\_FIF  
O**
**DL FIFO CONTROL REGISTER****00000000**

| <b>Bit</b>   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                          |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------|
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CR_I2S1_FIFO_DL_W_THRESHOLD |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW                          |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0                           |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                           |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CR_I2S1_FIFO_DL_R_THRESHOLD |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW                          |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0                           |

**Overview**

| <b>Bit(s)</b> | <b>Mnemonic</b>                                               | <b>Name</b> | <b>Description</b> |
|---------------|---------------------------------------------------------------|-------------|--------------------|
| 27:24         | CR_I2S1_F CR_I2S1_FIFO_DL<br>IFO_DL_W_W_THRESHOLD<br>_THRESHO |             | Reserved           |

---

|      |                                                                             |
|------|-----------------------------------------------------------------------------|
|      | LD                                                                          |
| 16   | CR_I2S1_F CR_I2S1_FIFO_DL Reserved<br>IFO_DL_W_WCLEAR<br>CLEAR              |
| 11:8 | CR_I2S1_F CR_I2S1_FIFO_DL Reserved<br>IFO_DL_R_R_THRESHOLD<br>THRESHO<br>LD |
| 0    | CR_I2S1_F CR_I2S1_FIFO_DL Reserved<br>IFO_DL_R_RCLEAR<br>CLEAR              |

---

| <b>A0080014 I2S1 UL FIF O</b> |    |    |    |    |                             |    |    |    |    |    |    |    |    |    |    | <b>UL FIFO CONTROL REGISTER</b> |                                                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>00000000</b> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------------|----|----|----|----|-----------------------------|----|----|----|----|----|----|----|----|----|----|---------------------------------|--------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-----------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Bit                           | 31 | 30 | 29 | 28 | 27                          | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                              | CR<br>I2<br>S1<br>FIF<br>O<br>UL<br>W<br>CL<br>EA<br>R |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name                          |    |    |    |    | CR_I2S1_FIFO_UL_W_THRESHOLD |    |    |    |    |    |    |    |    |    |    |                                 |                                                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type                          |    |    |    |    | RW                          |    |    |    |    |    |    |    |    |    |    |                                 | RW                                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reset                         |    |    |    |    | 0                           | 0  | 0  | 0  |    |    |    |    |    |    |    |                                 | 0                                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Bit                           | 15 | 14 | 13 | 12 | 11                          | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                               |                                                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name                          |    |    |    |    | CR_I2S1_FIFO_UL_R_THRESHOLD |    |    |    |    |    |    |    |    |    |    |                                 | CR<br>I2<br>S1<br>FIF<br>O<br>UL<br>R<br>CL<br>EA<br>R |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type                          |    |    |    |    | RW                          |    |    |    |    |    |    |    |    |    |    |                                 | RW                                                     |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reset                         |    |    |    |    | 0                           | 0  | 0  | 0  |    |    |    |    |    |    |    |                                 | 0                                                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

### Overview

---

| Bit(s) | Mnemonic            | Name                        | Description |
|--------|---------------------|-----------------------------|-------------|
| 27:24  | CR_I2S1_FIFO_UL_W_T | CR_I2S1_FIFO_UL_W_THRESHOLD | Reserved    |
| 16     | CR_I2S1_FIFO_UL_WCL | CR_I2S1_FIFO_UL_WCLEAR      | Reserved    |
| 11:8   | CR_I2S1_FIFO_UL_R_T | CR_I2S1_FIFO_UL_R_THRESHOLD | Reserved    |
| 0      | CR_I2S1_FIFO_UL_RCL | CR_I2S1_FIFO_UL_RCLEAR      | Reserved    |

---

| <b>A0080018 I2S1 DL FIF O STATUS</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>DL FIFO CONTROL STATUS REGISTER</b> |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  | <b>00000000</b> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|--------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------------------------------|-------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|-----------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Bit                                  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                                     | CR_I2S1_FIFO_DL_W |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name                                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                        |                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

Aoo80018 I2S1\_DL\_FIF  
O\_STATUS

## DL FIFO CONTROL STATUS REGISTER

oooooooooo

| Type  |                               |    |    |    |    |    |   |   |   |   |   |   |   |   | FIFO_CNT               |         |  |  |
|-------|-------------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|------------------------|---------|--|--|
| Reset |                               |    |    |    |    |    |   |   |   |   |   |   |   |   | RO                     |         |  |  |
| Bit   | 15                            | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1                      | 0       |  |  |
| Name  | CR_I2S1_FIFO_DL_RF<br>IFO_CNT |    |    |    |    |    |   |   |   |   |   |   |   |   | CR_I2S1_FIFO_DL_STATUS |         |  |  |
| Type  | RO                            |    |    |    |    |    |   |   |   |   |   |   |   |   | RO                     |         |  |  |
| Reset | 0 0 0 0                       |    |    |    |    |    |   |   |   |   |   |   |   |   | 0 0 0 0                | 0 0 0 0 |  |  |

## Overview

| Bit(s) | Mnemonic           | Name            | Description            |
|--------|--------------------|-----------------|------------------------|
| 19:16  | CR_I2S1_F          | CR_I2S1_FIFO_DL | Reserved               |
|        | IFO_DL_W_WFIFO_CNT |                 |                        |
|        | FIFO_CNT           |                 |                        |
| 11:8   | CR_I2S1_F          | CR_I2S1_FIFO_DL | Reserved               |
|        | IFO_DL_R_RFIFO_CNT |                 |                        |
|        | FIFO_CNT           |                 |                        |
| 5:0    | CR_I2S1_F          | CR_I2S1_FIFO_DL | [5] CR_FIFO_DL_W_READY |
|        | IFO_DL_ST_STATUS   |                 | [4] CR_FIFO_DL_R_READY |
|        | ATUS               |                 | [3] CR_FIFO_DL_FDLL    |
|        |                    |                 | [2] CR_FIFO_DL_AFULL   |
|        |                    |                 | [1] CR_FIFO_DL_EMPTY   |
|        |                    |                 | [0] CR_FIFO_DL_AEMPTY  |

| Type  |                               |    |    |    |    |    |    |    |    |    |    |    |    |    | CR_I2S1_FIFO_UL_W<br>IFO_CNT |         |  |  |
|-------|-------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------------------|---------|--|--|
| Reset |                               |    |    |    |    |    |    |    |    |    |    |    |    |    | RO                           |         |  |  |
| Bit   | 31                            | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17                           | 16      |  |  |
| Name  | CR_I2S1_FIFO_UL_RF<br>IFO_CNT |    |    |    |    |    |    |    |    |    |    |    |    |    | CR_I2S1_FIFO_UL_STATUS       |         |  |  |
| Type  | RO                            |    |    |    |    |    |    |    |    |    |    |    |    |    | RO                           |         |  |  |
| Reset | 0 0 0 0                       |    |    |    |    |    |    |    |    |    |    |    |    |    | 0 0 0 0                      | 0 0 0 0 |  |  |

## Overview

| Bit(s) | Mnemonic           | Name            | Description            |
|--------|--------------------|-----------------|------------------------|
| 19:16  | CR_I2S1_F          | CR_I2S1_FIFO_UL | Reserved               |
|        | IFO_UL_W_WFIFO_CNT |                 |                        |
|        | FIFO_CNT           |                 |                        |
| 11:8   | CR_I2S1_F          | CR_I2S1_FIFO_UL | Reserved               |
|        | IFO_UL_R_RFIFO_CNT |                 |                        |
|        | FIFO_CNT           |                 |                        |
| 5:0    | CR_I2S1_F          | CR_I2S1_FIFO_UL | [5] CR_FIFO_UL_W_READY |
|        | IFO_UL_ST_STATUS   |                 | [4] CR_FIFO_UL_R_READY |
|        | ATUS               |                 | [3] CR_FIFO_UL_FULL    |
|        |                    |                 | [2] CR_FIFO_UL_AFULL   |
|        |                    |                 | [1] CR_FIFO_UL_EMPTY   |
|        |                    |                 | [0] CR_FIFO_UL_AEMPTY  |

**A008002    I<sub>2</sub>S<sub>1</sub> SCAN  
0            RSV**
**SCAN RESERVED REGISTER****00000000**

| Bit   | 31                                                   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|------------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | <b>CR_I<sub>2</sub>S<sub>1</sub>_RESERVED[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW                                                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                                                    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15                                                   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>CR_I<sub>2</sub>S<sub>1</sub>_RESERVED[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW                                                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                                                    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**Overview**

| Bit(s) | Mnemonic                               | Name                                         | Description     |
|--------|----------------------------------------|----------------------------------------------|-----------------|
| 31:0   | <b>CR_I<sub>2</sub>S<sub>1</sub>_R</b> | <b>CR_I<sub>2</sub>S<sub>1</sub>_RESERVE</b> | <b>Reserved</b> |

**A008003    I<sub>2</sub>S<sub>1</sub> GLOBA  
0            L\_EN\_CONT  
              ROL**
**AUDIO TOP ENABLE CONTROL REGISTER****01000000**

| Bit   | 31                                              | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|-------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | <b>CR_I<sub>2</sub>S<sub>1</sub>_UL_FIFO_EN</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 1                                               |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0  |
| Bit   | 15                                              | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>CR_I<sub>2</sub>S<sub>1</sub>_DL_FIFO_EN</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW                                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                                               |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0  |

**Overview**

| Bit(s) | Mnemonic                                        | Name                                            | Description                                      |
|--------|-------------------------------------------------|-------------------------------------------------|--------------------------------------------------|
| 24     | <b>CR_PDN_AUD_26M</b>                           | <b>CR_PDN_AUD_26M</b>                           | <b>o: Normal</b><br>1: Power down                |
| 16     | <b>CR_I<sub>2</sub>S<sub>1</sub>_UL_FIFO_EN</b> | <b>CR_I<sub>2</sub>S<sub>1</sub>_UL_FIFO_EN</b> | <b>UL_FIFO enable</b><br>o: disable<br>1: enable |
| 8      | <b>CR_I<sub>2</sub>S<sub>1</sub>_DL_FIFO_EN</b> | <b>CR_I<sub>2</sub>S<sub>1</sub>_DL_FIFO_EN</b> | <b>DL_FIFO enable</b><br>o: disable<br>1: enable |
| 0      | <b>CR_I<sub>2</sub>S<sub>1</sub>_ENABLE</b>     | <b>CR_I<sub>2</sub>S<sub>1</sub>_ENABLE</b>     | <b>Audio top enable</b><br>o: disable            |

1: enable

**Aoo8003 4 I2S1\_DL\_SR  
EN CONTR OL**      **DL I2S SAMPLE RATE ENABLE CONTROL REGISTER**      **00010000**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16              |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CR_P_DN_I2_SO1  |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW              |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 1               |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0               |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CR_I2_S1_OUT_SR |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW              |
| Reset |    |    |    |    | 0  | 0  | 0  | 0  | 0  |    |    |    |    |    |    | 0               |

**Overview**

| Bit(s) | Mnemonic      | Name                    | Description                                                                                                                                                                                                                                                                                              |
|--------|---------------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16     | CR_PDN_I2_SO1 | CR_PDN_I2_SO1           | <b>o: Normal</b><br>1: Power down                                                                                                                                                                                                                                                                        |
| 12:8   | CR_I2S1_O     | CR_I2S1_OUT_SR<br>UT_SR | <b>[11:8]I2S mode select:</b><br>0000b: 8kHz<br>0001b: 11.025kHz<br>0010b: 12kHz<br>0100b: 16kHz<br>0101b: 22.05kHz<br>0110b: 24kHz<br>1000b: 32kHz<br>1001b: 44.1kHz<br>1010b: 48kHz<br>1011b: 88.2kHz<br>1100b: 96kHz<br>1101b: 176.4kHz<br>1110b: 192kHz<br><br>[12] hd_en<br>0: disable<br>1: enable |
| 0      | CR_I2S1_O     | CR_I2S1_OUT_EN<br>UT_EN | <b>I2S out enable</b><br>0: disable<br>1: enable                                                                                                                                                                                                                                                         |

**Aoo8003 8 I2S1\_UL\_SR  
EN CONTR OL**      **UL I2S SAMPLE RATE ENABLE CONTROL REGISTER**      **00010000**

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16      |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------|
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CR_P_DN |

Aoo8003  
8I2S1 UL SR  
EN CONTR  
OLUL I2S SAMPLE RATE ENABLE CONTROL  
REGISTER

00010000

|       |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |                                                               | <u>I2</u><br><u>SIN</u><br><u>1</u> |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---------------------------------------------------------------|-------------------------------------|
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW                                                            |                                     |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 1                                                             |                                     |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                                                             |                                     |
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <u>CR</u><br><u>I2</u><br><u>S1</u><br><u>IN</u><br><u>EN</u> |                                     |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW                                                            |                                     |
| Reset |    |    |    | o  | o  | o  | o | o |   |   |   |   |   |   |   | o                                                             |                                     |

**Overview**

| Bit(s) | Mnemonic         | Name                 | Description                                                                                                                                                                                                                                                 |
|--------|------------------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16     | <b>CR_PDN_I</b>  | <b>CR_PDN_I2SIN1</b> | <b>o: Normal</b><br>1: Power down                                                                                                                                                                                                                           |
| 12:8   | <b>CR_I2S1_I</b> | <b>CR_I2S1_IN_SR</b> | <b>[11:8]I2S mode select:</b><br>0000b: 8kHz<br>0001b: 11.025kHz<br>0010b: 12kHz<br>0100b: 16kHz<br>0101b: 22.05kHz<br>0110b: 24kHz<br>1000b: 32kHz<br>1001b: 44.1kHz<br>1010b: 48kHz<br>1011b: 88.2kHz<br>1100b: 96kHz<br>1101b: 176.4kHz<br>1110b: 192kHz |
| 0      | <b>CR_I2S1_I</b> | <b>CR_I2S1_IN_EN</b> | [12] hd_en<br>0: disable<br>1: enable                                                                                                                                                                                                                       |
| 0      | <b>CR_I2S1_I</b> | <b>N_EN</b>          | <b>I2S out enable</b><br>0: disable<br>1: enable                                                                                                                                                                                                            |

Aoo8003  
CI2S MONITO  
R

I2S\_MONITOR

00000000

| Bit   | 31                    | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|-----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | CR_I2S_MONITOR[31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                     | o  | o  | o  | o  | o  | o  | o  | o  | o  | o  | o  | o  | o  | o  | o  |
| Bit   | 15                    | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | o  |
| Name  | CR_I2S_MONITOR[15:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                     | o  | o  | o  | o  | o  | o  | o  | o  | o  | o  | o  | o  | o  | o  | o  |

**Overview**

| Bit(s) | Mnemonic | Name           | Description                                                  |
|--------|----------|----------------|--------------------------------------------------------------|
| 31:0   | CR_I2S_M | CR_I2S_MONITOR | [15:8] i2s_out_bcount_monitor<br>[7:0] i2s_in_bcount_monitor |

**Aoo8004 I2S1\_DL\_INT CONTROL I2S DL INTERRUPT ENABLE CONTROL REGISTER 00000000**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24                                     | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                                         |
|-------|----|----|----|----|----|----|----|----------------------------------------|----|----|----|----|----|----|----|--------------------------------------------|
| Name  |    |    |    |    |    |    |    |                                        |    |    |    |    |    |    |    |                                            |
| Type  |    |    |    |    |    |    |    |                                        |    |    |    |    |    |    |    |                                            |
| Reset |    |    |    |    |    |    |    |                                        |    |    |    |    |    |    |    |                                            |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8                                      | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                                          |
| Name  |    |    |    |    |    |    |    | CR<br>D<br>L_I<br>NT<br>STS<br>IN<br>T |    |    |    |    |    |    |    | CR<br>D<br>L<br>CO<br>NT<br>RL<br>IT<br>EN |
| Type  |    |    |    |    |    |    |    | RO                                     |    |    |    |    |    |    |    | RW                                         |
| Reset |    |    |    |    |    |    |    | o                                      |    |    |    |    |    |    |    | o                                          |

**Overview**

| Bit(s) | Mnemonic          | Name              | Description |
|--------|-------------------|-------------------|-------------|
| 8      | CR_DL_INTSTS_INT  | CR_DL_INTSTS_INT  |             |
| 0      | CR_DL CONTRL_ITEN | CR_DL CONTRL_ITEN |             |

**Aoo8004 I2S1\_UL\_INT CONTROL I2S UL INTERRUPT ENABLE CONTROL REGISTER 00000000**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24                                     | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                                         |
|-------|----|----|----|----|----|----|----|----------------------------------------|----|----|----|----|----|----|----|--------------------------------------------|
| Name  |    |    |    |    |    |    |    |                                        |    |    |    |    |    |    |    |                                            |
| Type  |    |    |    |    |    |    |    |                                        |    |    |    |    |    |    |    |                                            |
| Reset |    |    |    |    |    |    |    |                                        |    |    |    |    |    |    |    |                                            |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8                                      | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                                          |
| Name  |    |    |    |    |    |    |    | CR<br>U<br>L_I<br>NT<br>STS<br>IN<br>T |    |    |    |    |    |    |    | CR<br>U<br>L<br>CO<br>NT<br>RL<br>IT<br>EN |
| Type  |    |    |    |    |    |    |    | RO                                     |    |    |    |    |    |    |    | RW                                         |
| Reset |    |    |    |    |    |    |    | o                                      |    |    |    |    |    |    |    | o                                          |

**Overview**

| Bit(s) | Mnemonic          | Name              | Description |
|--------|-------------------|-------------------|-------------|
| 8      | CR_UL_INTSTS_INT  | CR_UL_INTSTS_INT  |             |
| 0      | CR_UL CONTRL_ITEN | CR_UL CONTRL_ITEN |             |

**A008004 I<sub>2</sub>S1 INT AC  
8 K CONTROL**

**I<sub>2</sub>S UL INTERRUPT ENABLE CONTROL  
REGISTER**

**00000000**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24                   | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                   |
|-------|----|----|----|----|----|----|----|----------------------|----|----|----|----|----|----|----|----------------------|
| Name  |    |    |    |    |    |    |    |                      |    |    |    |    |    |    |    |                      |
| Type  |    |    |    |    |    |    |    |                      |    |    |    |    |    |    |    |                      |
| Reset |    |    |    |    |    |    |    |                      |    |    |    |    |    |    |    |                      |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8                    | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                    |
| Name  |    |    |    |    |    |    |    | CR_D_L_AC_KI_NT_A_CK |    |    |    |    |    |    |    | CR_U_L_AC_KI_NT_A_CK |
| Type  |    |    |    |    |    |    |    | RW                   |    |    |    |    |    |    |    | RW                   |
| Reset |    |    |    |    |    |    |    | 0                    |    |    |    |    |    |    |    | 0                    |

## Overview

| Bit(s) | Mnemonic                               | Name | Description |
|--------|----------------------------------------|------|-------------|
| 8      | CR_DL_AC CR_DL_ACKINT_A<br>KINT_ACK CK |      |             |
| 0      | CR_UL_AC CR_UL_ACKINT_A<br>KINT_ACK CK |      |             |

## 12. I2S0 and I2S1 Audio PLL Settings

### 12.1. XPLL block diagram

The audio phase-locked loop (XPLL) supports:

- 1) REF\_CK: 26MHz or 40MHz.
- 2) PLL VCO frequency Output frequency: 832MHz, 786.432MHz or 722.5344MHz
- 3) PLL output frequency: 26MHz, 24.576MHz or 22.5792MHz



Figure 12.1-1. XPLL block diagram

Keywords: analog PLL core, CHPFD, LPF, VCO, FB\_CK

### 12.2. Fractional-N PLL power on sequence

- 1) Set RG\_XPLL\_FBDIV<6:0> to nearest integer
- 2) PLL power on and settle (after AD\_RGS\_PLL\_VCO\_CPLT=1)
- 3) Set DDS power on registers



**Figure 12.2-1. Fractional-N PLL power on sequence**

Keywords: XPLL calibration, XPLL ready

### 12.3. XPLL frequency setting (Integer)

$$\text{Freq} = \text{Fin} * (\text{FBDIV} + 1) * \text{FBSEL} / \text{PREDIV} / \text{POSDIV}$$

- 1) Pre-divider ratio (PREDIV)
  - 2'b00: Fref = Fin/1
  - 2'b01: Fref = Fin/2
  - 2'b1X: Fref = Fin/4
- 2) Post-divider ratio for single-phase output (POS DIV)
  - 2'b00: VCO/1
  - 2'b01: VCO/2
  - 2'b1X: VCO/4
- 3) Feedback clock select (FBSEL)
  - 2'b00: Fvco/1
  - 2'b01: Fvco/2
  - 2'b1X: Fvco/4
- 4) Feedback divide ratio (FBDIV)
  - 7'd0: /1
  - 7'd1: /2

.....  
7'd127: /128

## 12.4. DDS PCW setting



Figure 12.4-1. DDS PCW settings

- 1)  $2 < \text{divisor} < 128$
  - 2)  $\text{RG_XPLL_PCW_NCPO}[30:0] = (\text{Period}-1)*2^{24}$
  - 3) Ex. Fin=26MHz, Fout=416MHz
- $\text{RG_XPLL_PCW_NCPO}[30:0]=(416/26-1)*2^{24}=16'd251658240$

## 12.5. XPLL frequency change sequence

- Set RG\_XPLL\_PCW\_NCPO<30:0>
  - Toggle RG\_XPLL\_PCW\_NCPO\_CHG
- (Both edges will do)



Figure 12.5-1. XPLL frequency change sequence

Keyword: RG\_XPLL\_PCW\_MCPO

## 12.6. XPLL turn on programming sequence

Read CKSYS\_XTAL\_FREQ\_\_F\_F\_FXO\_IS\_26M (0xA20202A3) for REF\_CK (1: 26MHz, 0: 40MHz)

- 1) If REF\_CK = 26MHz, AD\_XPLL\_CK = 26MHz
- Write: XPLL\_CTL0 = 0x441F;
  - Write: XPLL\_CTL1 = 0x441F;
  - Write: XPLL\_CTL2 = 0x7320;
  - Write: XPLL\_CTL3 = 0x1E000000;
  - Write: XPLL\_CTL8 = 0x2F00;
  - Wait: 20us;
  - Write: XPLL\_CTL0 = 0x441E;
  - Write: XPLL\_CTL8 = 0x2F008;
  - Polling: XPLL\_CTL4[1] = 1; //bit[1]: AD\_RGS\_PLL\_VCOCAL\_CPLT

- Write: XPLL\_CTL4 = 0x2A;
- Write: XPLL\_CTL8 = 0x2F018;
- Write: XPLL\_CTL3 = 0x1E000001;
- Wait: 1us;
- Write: XPLL\_CTL8 = 0x2F038;
- Wait: 1us;
- Write: XPLL\_CTL2 = 0xF302;
- Write: XPLL\_CTL8 = 0xF038;
- Wait: 20us;

2) If REF\_CK = 26MHz, AD\_XPLL\_CK = 24.576MHz

- Write: XPLL\_CTL0 = 0x441D;
- Write: XPLL\_CTL1 = 0xD861;
- Write: XPLL\_CTL2 = 0x7302;
- Write: XPLL\_CTL3 = 0x1C3F549A;
- Write: XPLL\_CTL8 = 0x20000;
- Wait: 20us;
- Write: XPLL\_CTL0 = 0x441C;
- Write: XPLL\_CTL8 = 0x20008;
- Polling: XPLL\_CTL4[1] = 1; //bit[1]: AD\_RGS\_PLL\_VCOCAL\_CPLT
- Write: XPLL\_CTL4 = 0x2A;
- Write: XPLL\_CTL8 = 0x20018;
- Write: XPLL\_CTL3 = 0x1C3F549B;
- Wait: 1us;
- Write: XPLL\_CTL8 = 0x20038;
- Wait: 1us;
- Write: XPLL\_CTL2 = 0xF302;
- Write: XPLL\_CTL8 = 0x38;
- Wait: 20us;

3) If REF\_CK = 26MHz, AD\_XPLL\_CK = 22.5792MHz

- Write: XPLL\_CTL0 = 0x435;
- Write: XPLL\_CTL1 = 0xC861;
- Write: XPLL\_CTL2 = 0x7302;
- Write: XPLL\_CTL3 = 0x19CA2F54;
- Write: XPLL\_CTL8 = 0x2F000;

- Wait: 20us;
- Write: XPLL\_CTL0 = 0x434;
- Write: XPLL\_CTL8 = 0x2F008;
- Polling: XPLL\_CTL4[1] = 1; //bit[1]: AD\_RGS\_PLL\_VCOCAL\_CPLT
- Write: XPLL\_CTL4 = 0x2A;
- Write: XPLL\_CTL8 = 0x2F018;
- Write: XPLL\_CTL3 = 0x19CA2F55;
- Wait: 1us;
- Write: XPLL\_CTL8 = 0x2F038;
- Wait: 1us;
- Write: XPLL\_CTL2 = 0xF302;
- Write: XPLL\_CTL8 = 0xF038;
- Wait: 20us;

4) If REF\_CK = 40MHz, AD\_XPLL\_CK = 26MHz

- Write: XPLL\_CTL0 = 0x4413;
- Write: XPLL\_CTL1 = 0x6861;
- Write: XPLL\_CTL2 = 0x7303;
- Write: XPLL\_CTL3 = 0x12CCCCC;
- Write: XPLL\_CTL8 = 0x2F000;
- Wait: 20us;
- Write: XPLL\_CTL0 = 0x4412;
- Write: XPLL\_CTL8 = 0x2F008;
- Polling: XPLL\_CTL4[1] = 1; //bit[1]: AD\_RGS\_PLL\_VCOCAL\_CPLT
- Write: XPLL\_CTL4 = 0x2A;
- Write: XPLL\_CTL8 = 0x2F008;
- Write: XPLL\_CTL3 = 0x12CCCCD;
- Wait: 1us;
- Write: XPLL\_CTL8 = 0x2F038;
- Wait: 1us;
- Write: XPLL\_CTL2 = 0xF303;
- Write: XPLL\_CTL8 = 0xF038;
- Wait: 20us;

5) If REF\_CK = 40MHz, AD\_XPLL\_CK = 24.576MHz

- Write: XPLL\_CTL0 = 0x4411;

- Write: XPLL\_CTL1 = 0x5861;
  - Write: XPLL\_CTL2 = 0x7303;
  - Write: XPLL\_CTL3 = 0x11A92A30;
  - Write: XPLL\_CTL8 = 0x2F000;
  - Wait: 20us;
  - Write: XPLL\_CTL0 = 0x4410;
  - Write: XPLL\_CTL8 = 0x2F008;
  - Polling: XPLL\_CTL4[1] = 1; //bit[1]: AD\_RGS\_PLL\_VCOCAL\_CPLT
  - Write: XPLL\_CTL4 = 0x2A;
  - Write: XPLL\_CTL8 = 0x2F018;
  - Write: XPLL\_CTL3 = 0x11A92A31;
  - Wait: 1us;
  - Write: XPLL\_CTL8 = 0x2F038;
  - Wait: 1us;
  - Write: XPLL\_CTL2 = 0xF303;
  - Write: XPLL\_CTL8 = 0xF038;
  - Wait: 20us;
- 6) If REF\_CK = 40MHz, AD\_XPLL\_CK = 22.5792MHz
- Write: XPLL\_CTL0 = 0x423;
  - Write: XPLL\_CTL1 = 0x5861;
  - Write: XPLL\_CTL2 = 0x7303;
  - Write: XPLL\_CTL3 = 0x1010385C;
  - Write: XPLL\_CTL8 = 0x2F000;
  - Wait: 20us;
  - Write: XPLL\_CTL0 = 0x422;
  - Write: XPLL\_CTL8 = 0x2F008;
  - Polling: XPLL\_CTL4[1] = 1; //bit[1]: AD\_RGS\_PLL\_VCOCAL\_CPLT
  - Write: XPLL\_CTL4 = 0x2A;
  - Write: XPLL\_CTL8 = 0x2F018;
  - Write: XPLL\_CTL3 = 0x1010385D;
  - Wait: 1us;
  - Write: XPLL\_CTL8 = 0x2F038;
  - Wait: 1us;
  - Write: XPLL\_CTL2 = 0xF303;
  - Write: XPLL\_CTL8 = 0xF038;

- Wait: 20us;

## 12.7. XPLL turn off programming sequence

- 1) To turn off XPLL when no need:

- Write: XPLL\_CTL0[0] = 1;
- Wait: 1us;
- Write: XPLL\_CTL8[3] = 0;
- Wait: 1us;
- Write: XPLL\_CTL8[16] = 1;

## 13. SDIO

### 13.1. Overview

The SD Input/Output (SDIO) card is based on and compatible with the SD memory card. The controller fully supports the SD memory card bus protocol as defined in SD Memory Card Specification Part 1 Physical Layer Specification version 2.0 and SDIO Specification version 2.0.

SDIO provides high-speed data IO with low power consumption. MT7682 SDIO module provides an SDIO2.0 card interface connected to the host and can support multiple speed modes including default speed, SDR12 and SDR25.

### 13.2. Features

- Provides SDIO2.0 host interfaces
  - SDIO2.0:
    - 1-bit and 4-bit SD data transfer modes
    - Default mode: Variable clock rate 0-25 MHz, up to 12.5 MB/sec interface speed (using 4 parallel data lines)
    - High-Speed mode: Variable clock rate 0-50 MHz, up to 25 MB/sec interface speed (using 4 data lines)
    - Data rate up to 50Mbps in serial mode, 50 x 4 Mbps in parallel mode, the module is targeted at 50MHz operating clock.
    - 32-bit access for control registers
    - 32-bit access for FIFO
    - Built-in 32 bytes FIFO buffers for transmit and receive, FIFO is shared for transmit and receive
    - Built-in CRC circuit
    - Interrupt capabilities
    - Does not support SPI
    - Supports DMA
    - WLAN TX packet de-aggregation and WLAN RX packet aggregation
    - WLAN WHISR/ RX enhanced read mode
  - CR and data port access
    - Supports CR port single read/write access (AHB slave)
    - Supports data port single and burst read/write access (AHB master)
  - DMA function
    - One TX channel and two RX channels
    - AHB master interface
    - Moves TX data from HIF buffer to system, EMI, retention memory
    - Moves RX data or firmware prepared data from system, EMI, retention memory to HIF buffer

### 13.3. Block diagram

The block diagram of the SDIO controller is shown in Figure 13.3-1.



Figure 13.3-1. SDIO controller block diagram

### 13.4. Functions

From the external view, the SDIO interface mainly includes the SD bus and AHB master and slave. The AHB master is used for DMA operations and the AHB slave is used for register access from the MCU. The SD bus provides an interface for SD specification.

#### 13.4.1. Signal pins



Figure 13.4-1. Signal connections to 4-bit SDIO cards

Table 13.4-1. SDIO pin definitions

| Pin | Name        | SD 4-bit mode |              | SD 1-bit mode |              |
|-----|-------------|---------------|--------------|---------------|--------------|
| 1   | SLV_MC0_DA3 | DAT[3]        | Data line3   | N/C           | Not used     |
| 2   | SLV_MC0_CM0 | CMD           | Command line | CMD           | Command line |
| 3   | VSS1        | VSS1          | Ground       | VSS1          | Ground       |

| Pin | Name        | SD 4-bit mode |                         | SD 1-bit mode |                |
|-----|-------------|---------------|-------------------------|---------------|----------------|
| 4   | VDD         | VDD           | Supply voltage          | VDD           | Supply voltage |
| 5   | SLV_MCO_CK  | CLK           | Clock                   | CLK           | Clock          |
| 6   | VSS2        | VSS2          | Ground                  | VSS2          | Ground         |
| 7   | SLV_MCO_DA0 | DAT[0]        | Data line 0             | DATA          | Data line      |
| 8   | SLV_MCO_DA1 | DAT[1]        | Data line1 or interrupt | IRQ           | Interrupt      |
| 9   | SLV_MCO_DA2 | DAT[2]        | Data line2              | RW            | Not used       |

### 13.4.2. SDIO timing waveform (3.3V)



Figure 13.4-2. Bus signal levels

Table 13.4-2. Bus signal voltage

| Parameter           | Symbol | Min.      | Max.      | Unit | Conditions        |
|---------------------|--------|-----------|-----------|------|-------------------|
| Output High Voltage | VOH    | 0.75*VDD  |           | V    | IOH=-2mA VDD min  |
| Output Low Voltage  | VOL    |           | 0.125*VDD | V    | IOL = 2mA VDD min |
| Input High Voltage  | VIH    | 0.625*VDD | VDD+0.3   | V    |                   |
| Input Low Voltage   | VIL    | Vss-0.3   | 0.25*VDD  | V    |                   |

**Figure 13.4-3. Bus timing diagram (default)****Table 13.4-3. Bus timing parameter values (default)**

| Parameter                                                                                             | Symbol     | Minimum | Maximum | Unit | Remark                                 |
|-------------------------------------------------------------------------------------------------------|------------|---------|---------|------|----------------------------------------|
| <b>Clock CLK (All values are referred to min (<math>V_{IH}</math>) and max (<math>V_{IL}</math>))</b> |            |         |         |      |                                        |
| Clock frequency data transfer mode                                                                    | $f_{PP}$   | 0       | 25      | MHz  | $C_{CARD} \leq 10 \text{ pF}$ (1 card) |
| Clock frequency identification mode                                                                   | $f_{OD}$   | 0/100   | 400     | kHz  | $C_{CARD} \leq 10 \text{ pF}$ (1 card) |
| Clock low time                                                                                        | $t_{WL}$   | 10      |         | ns   | $C_{CARD} \leq 10 \text{ pF}$ (1 card) |
| Clock high time                                                                                       | $t_{WH}$   | 10      |         | ns   | $C_{CARD} \leq 10 \text{ pF}$ (1 card) |
| Clock rise time                                                                                       | $t_{TLH}$  |         | 10      | ns   | $C_{CARD} \leq 10 \text{ pF}$ (1 card) |
| Clock fall time                                                                                       | $t_{THL}$  |         | 10      | ns   | $C_{CARD} \leq 10 \text{ pF}$ (1 card) |
| <b>Inputs CMD, DAT (referenced to CLK)</b>                                                            |            |         |         |      |                                        |
| Input set-up time                                                                                     | $t_{ISU}$  | 5       |         | ns   | $C_{CARD} \leq 10 \text{ pF}$ (1 card) |
| Input hold time                                                                                       | $t_{IH}$   | 5       |         | ns   | $C_{CARD} \leq 10 \text{ pF}$ (1 card) |
| <b>Outputs CMD, DAT (referenced to CLK)</b>                                                           |            |         |         |      |                                        |
| Output delay time during data transfer mode                                                           | $t_{ODLY}$ | 0       | 14      | ns   | $C_L \leq 40 \text{ pF}$ (1 card)      |
| Output delay time during identification mode                                                          | $t_{ODLY}$ | 0       | 50      | ns   | $C_L \leq 40 \text{ pF}$ (1 card)      |



Figure 13.4-4. High-speed timing diagram

Table 13.4-4. High-speed timing parameter values

| Parameter                                                                                             | Symbol     | Minimum | Maximum | Unit | Remark                                 |
|-------------------------------------------------------------------------------------------------------|------------|---------|---------|------|----------------------------------------|
| <b>Clock CLK (All values are referred to min (<math>V_{IH}</math>) and max (<math>V_{IL}</math>))</b> |            |         |         |      |                                        |
| Clock frequency data transfer mode                                                                    | $f_{PP}$   | 0       | 50      | MHz  | $C_{CARD} \leq 10 \text{ pF}$ (1 card) |
| Clock low time                                                                                        | $t_{WL}$   | 7       |         | ns   | $C_{CARD} \leq 10 \text{ pF}$ (1 card) |
| Clock high time                                                                                       | $t_{WH}$   | 7       |         | ns   | $C_{CARD} \leq 10 \text{ pF}$ (1 card) |
| Clock rise time                                                                                       | $t_{TLH}$  |         | 3       | ns   | $C_{CARD} \leq 10 \text{ pF}$ (1 card) |
| Clock fall time                                                                                       | $t_{THL}$  |         | 3       | ns   | $C_{CARD} \leq 10 \text{ pF}$ (1 card) |
| <b>Inputs CMD, DAT (referenced to CLK)</b>                                                            |            |         |         |      |                                        |
| Input set-up time                                                                                     | $t_{ISU}$  | 6       |         | ns   | $C_{CARD} \leq 10 \text{ pF}$ (1 card) |
| Input hold time                                                                                       | $t_{IH}$   | 2       |         | ns   | $C_{CARD} \leq 10 \text{ pF}$ (1 card) |
| <b>Outputs CMD, DAT (referenced to CLK)</b>                                                           |            |         |         |      |                                        |
| Output delay time during data transfer mode                                                           | $t_{OLDY}$ |         | 14      | ns   | $C_L \leq 40 \text{ pF}$ (1 card)      |
| Output hold time                                                                                      | $t_{OH}$   | 2.5     |         | ns   | $C_L \geq 40 \text{ pF}$ (1 card)      |
| Total system capacitance for each line (1)                                                            | $C_L$      |         | 40      | pF   | 1 card                                 |

(1) In order to satisfy the serving time, the host shall drive only one card

## 13.5. Register mapping

### 13.5.1. Firmware register

**Module name: SDIO\_FW Base address: (+A1040000h)**

| Address | Name | Width (bits) | Register Functionality |
|---------|------|--------------|------------------------|
|         |      |              |                        |

|          |                              |    |                                                       |
|----------|------------------------------|----|-------------------------------------------------------|
| A1040000 | <b>HGFCR</b>                 | 32 | <b>HIF Global Firmware Configuration Register</b>     |
| A1040004 | <b>HGFISR</b>                | 32 | <b>HIF Global Firmware Interrupt Status Register</b>  |
| A1040008 | <b>HGFIER</b>                | 32 | <b>HIF Global Firmware Interrupt Enable Register</b>  |
| A1040010 | <b>HSDBDLSR</b>              | 32 | <b>HIF SDIO Bus Delay Selection Register</b>          |
| A1040014 | <b>HSDLRS</b>                | 32 | <b>HIF SRAM Delay Selection Register</b>              |
| A1040018 | <b>HCSDCR</b>                | 32 | <b>HIF Clock Stop Detection register</b>              |
| A104001C | <b>HGH2DR</b>                | 32 | <b>HIF Global Host to Device Register</b>             |
| A1040020 | <b>HDBGCR</b>                | 32 | <b>HIF Debug Control Register</b>                     |
| A104002C | <b>FWDSIOCR</b>              | 32 | <b>DS Pad Macro IO Control Register</b>               |
| A1040030 | <b>HGTMTCR</b>               | 32 | <b>Test Mode Trigger Control Register</b>             |
| A1040034 | <b>HGTMCR</b>                | 32 | <b>Test Mode Control Register</b>                     |
| A1040038 | <b>HGTMDPCRo</b>             | 32 | <b>Test Mode Data Pattern Control Register 0</b>      |
| A104003C | <b>HGTMDPCR1</b>             | 32 | <b>Test Mode Data Pattern Control Register 1</b>      |
| A1040040 | <b>FWCLKIOCR T28LP</b>       | 32 | <b>Clock Pad Macro IO Control Register</b>            |
| A1040044 | <b>FWCMDIOCR T28L<br/>P</b>  | 32 | <b>Command Pad Macro IO Control Register</b>          |
| A1040048 | <b>FWDATIOCR T28L<br/>P</b>  | 32 | <b>Data 0 Pad Macro IO Control Register</b>           |
| A104004C | <b>FWDAT1IOCR T28L<br/>P</b> | 32 | <b>Data 1 Pad Macro IO Control Register</b>           |
| A1040050 | <b>FWDAT2IOCR T28L<br/>P</b> | 32 | <b>Data 2 Pad Macro IO Control Register</b>           |
| A1040054 | <b>FWDAT3IOCR T28L<br/>P</b> | 32 | <b>Data 3 Pad Macro IO Control Register</b>           |
| A1040058 | <b>FWCLKDLYCR</b>            | 32 | <b>Clock Pad Macro Delay Chain Control Register</b>   |
| A104005C | <b>FWCMDDLYCR</b>            | 32 | <b>Command Pad Macro Delay Chain Control Register</b> |
| A1040060 | <b>FWODATDLYCR</b>           | 32 | <b>SDIO Output Data Delay Chain Control Register</b>  |
| A1040064 | <b>FWIDATDLYCR1</b>          | 32 | <b>SDIO Input Data Delay Chain Control Register 1</b> |
| A1040068 | <b>FWIDATDLYCR2</b>          | 32 | <b>SDIO Input Data Delay Chain Control Register 2</b> |
| A104006C | <b>FWILCHCR</b>              | 32 | <b>SDIO Input Data Latch Time Control Register</b>    |
| A1040070 | <b>CISoR00</b>               | 32 | <b>CISo Register 0</b>                                |
| A1040074 | <b>CISoR01</b>               | 32 | <b>CISo Register 1</b>                                |
| A1040078 | <b>CISoR02</b>               | 32 | <b>CISo Register 2</b>                                |
| A104007C | <b>CISoR03</b>               | 32 | <b>CISo Register 3</b>                                |
| A1040080 | <b>CISoR04</b>               | 32 | <b>CISo Register 4</b>                                |
| A1040084 | <b>CISoR05</b>               | 32 | <b>CISo Register 5</b>                                |

|          |                  |    |                                                     |
|----------|------------------|----|-----------------------------------------------------|
| A1040088 | <u>CISoRo6</u>   | 32 | <b>CISo Register 6</b>                              |
| A104008C | <u>CISoRo7</u>   | 32 | <b>CISo Register 7</b>                              |
| A1040090 | <u>CISoRo8</u>   | 32 | <b>CISo Register 8</b>                              |
| A1040094 | <u>CISoRo9</u>   | 32 | <b>CISo Register 9</b>                              |
| A1040098 | <u>CISoRoA</u>   | 32 | <b>CISo Register A</b>                              |
| A104009C | <u>CISoRoB</u>   | 32 | <b>CISo Register B</b>                              |
| A10400Ao | <u>CISoRoC</u>   | 32 | <b>CISo Register C</b>                              |
| A10400A4 | <u>CISoRoD</u>   | 32 | <b>CISo Register D</b>                              |
| A10400A8 | <u>CISoRoE</u>   | 32 | <b>CISo Register E</b>                              |
| A10400AC | <u>CISoRoF</u>   | 32 | <b>CISo Register F</b>                              |
| A10400Bo | <u>CIS1Ro0</u>   | 32 | <b>CIS1 Register 0</b>                              |
| A10400B4 | <u>CIS1Ro1</u>   | 32 | <b>CIS1 Register 1</b>                              |
| A10400B8 | <u>CIS1Ro2</u>   | 32 | <b>CIS1 Register 2</b>                              |
| A10400BC | <u>CIS1Ro3</u>   | 32 | <b>CIS1 Register 3</b>                              |
| A10400Co | <u>CIS1Ro4</u>   | 32 | <b>CIS1 Register 4</b>                              |
| A10400C4 | <u>CIS1Ro5</u>   | 32 | <b>CIS1 Register 5</b>                              |
| A10400C8 | <u>CIS1Ro6</u>   | 32 | <b>CIS1 Register 6</b>                              |
| A10400CC | <u>CIS1Ro7</u>   | 32 | <b>CIS1 Register 7</b>                              |
| A10400Do | <u>CIS1Ro8</u>   | 32 | <b>CIS1 Register 8</b>                              |
| A10400D4 | <u>CIS1Ro9</u>   | 32 | <b>CIS1 Register 9</b>                              |
| A10400D8 | <u>CIS1RoA</u>   | 32 | <b>CIS1 Register A</b>                              |
| A10400DC | <u>CIS1RoB</u>   | 32 | <b>CIS1 Register B</b>                              |
| A10400Eo | <u>CIS1RoC</u>   | 32 | <b>CIS1 Register C</b>                              |
| A10400E4 | <u>CIS1RoD</u>   | 32 | <b>CIS1 Register D</b>                              |
| A10400E8 | <u>CIS1RoE</u>   | 32 | <b>CIS1 Register E</b>                              |
| A10400EC | <u>CIS1RoF</u>   | 32 | <b>CIS1 Register F</b>                              |
| A10400Fo | <u>CISRDY</u>    | 32 | <b>CIS Ready Flag Register</b>                      |
| A10400F4 | <u>CCCRo</u>     | 32 | <b>CC Register 0</b>                                |
| A10400F8 | <u>CCCR1</u>     | 32 | <b>CC Register 1</b>                                |
| A10400FC | <u>CCRDY</u>     | 32 | <b>CC Ready Flag Register</b>                       |
| A1040100 | <u>HWFISR</u>    | 32 | <b>HIF WLAN Firmware Interrupt Status Register</b>  |
| A1040104 | <u>HWFIER</u>    | 32 | <b>HIF WLAN Firmware Interrupt Enable Register</b>  |
| A1040108 | <u>HWFISR1</u>   | 32 | <b>Reserved for HWFISR1</b>                         |
| A104010C | <u>HWFIER1</u>   | 32 | <b>Reserved for HWFIER1</b>                         |
| A1040110 | <u>HWFTEOSR</u>  | 32 | <b>HIF WLAN Firmware TX Event o Status Register</b> |
| A1040114 | <u>HWFTEO1SR</u> | 32 | <b>Reserved for HWFTEO1SR</b>                       |
| A1040118 | <u>HWFTEO2SR</u> | 32 | <b>Reserved for HWFTEO2SR</b>                       |
| A104011C | <u>HWFTEO3SR</u> | 32 | <b>Reserved for HWFTEO3SR</b>                       |
| A1040120 | <u>HWFTEOER</u>  | 32 | <b>HIF WLAN Firmware TX Event o Enable Register</b> |

|          |                         |    |                                                                         |
|----------|-------------------------|----|-------------------------------------------------------------------------|
| A1040124 | <b><u>HWFTE1ER</u></b>  | 32 | <b>Reserved for HWFTE1ER</b>                                            |
| A1040128 | <b><u>HWFTE2ER</u></b>  | 32 | <b>Reserved for HWFTE2ER</b>                                            |
| A104012C | <b><u>HWFTE3ER</u></b>  | 32 | <b>Reserved for HWFTE3ER</b>                                            |
| A1040130 | <b><u>HWFREoSR</u></b>  | 32 | <b>HIF WLAN Firmware RX Event 0 Status Register</b>                     |
| A1040134 | <b><u>HWFRE1SR</u></b>  | 32 | <b>HIF WLAN Firmware RX Event 1 Status Register</b>                     |
| A1040138 | <b><u>HWFRE2SR</u></b>  | 32 | <b>Reserve for HWFRE2SR</b>                                             |
| A104013C | <b><u>HWFRE3SR</u></b>  | 32 | <b>Reserve for HWFRE3SR</b>                                             |
| A1040140 | <b><u>HWFREoER</u></b>  | 32 | <b>HIF WLAN Firmware RX Event 0 Enable Register</b>                     |
| A1040144 | <b><u>HWFRE1ER</u></b>  | 32 | <b>HIF WLAN Firmware RX Event 1 Enable Register</b>                     |
| A1040148 | <b><u>HWFRE2ER</u></b>  | 32 | <b>Reserve for HWFRE2ER</b>                                             |
| A104014C | <b><u>HWFRE3ER</u></b>  | 32 | <b>Reserve for HWFRE3ER</b>                                             |
| A1040150 | <b><u>HWFICR</u></b>    | 32 | <b>HIF WLAN Firmware Interrupt Control Register</b>                     |
| A1040154 | <b><u>WFCR</u></b>      | 32 | <b>HIF WLAN Firmware Control Register</b>                               |
| A1040158 | <b><u>HTDCR</u></b>     | 32 | <b>HIF WLAN TX DMA Control Register</b>                                 |
| A104015C | <b><u>HTPCCR</u></b>    | 32 | <b>HIF WLAN TX Packet Count Control Register</b>                        |
| A1040160 | <b><u>HWFTQoSAR</u></b> | 32 | <b>HIF WLAN Firmware TX Queue 0 Start Address Register</b>              |
| A1040164 | <b><u>HWFTQ1SAR</u></b> | 32 | <b>HIF WLAN Firmware TX Queue 1 Start Address Register</b>              |
| A1040168 | <b><u>HWFTQ2SAR</u></b> | 32 | <b>HIF WLAN Firmware TX Queue 2 Start Address Register</b>              |
| A104016C | <b><u>HWFTQ3SAR</u></b> | 32 | <b>HIF WLAN Firmware TX Queue 3 Start Address Register</b>              |
| A1040170 | <b><u>HWFTQ4SAR</u></b> | 32 | <b>HIF WLAN Firmware TX Queue 4 Start Address Register</b>              |
| A1040174 | <b><u>HWFTQ5SAR</u></b> | 32 | <b>Reserved for HIF WLAN Firmware TX Queue 5 Start Address Register</b> |
| A1040178 | <b><u>HWFTQ6SAR</u></b> | 32 | <b>Reserved for HIF WLAN Firmware TX Queue 6 Start Address Register</b> |
| A104017C | <b><u>HWFTQ7SAR</u></b> | 32 | <b>Reserved for HIF WLAN Firmware TX Queue 7 Start Address Register</b> |
| A1040180 | <b><u>HWFRQoSAR</u></b> | 32 | <b>HIF WLAN Firmware RX Queue 0 Start Address Register</b>              |
| A1040184 | <b><u>HWFRQ1SAR</u></b> | 32 | <b>HIF WLAN Firmware RX Queue 1 Start Address Register</b>              |
| A1040188 | <b><u>HWFRQ2SAR</u></b> | 32 | <b>HIF WLAN Firmware RX Queue 2 Start Address Register</b>              |
| A104018C | <b><u>HWFRQ3SAR</u></b> | 32 | <b>HIF WLAN Firmware RX Queue 3 Start Address Register</b>              |
| A1040190 | <b><u>HWFRQ4SAR</u></b> | 32 | <b>Reserve for HIF WLAN Firmware RX Queue 4 Start Address Register</b>  |

|          |                           |    |                                                                         |
|----------|---------------------------|----|-------------------------------------------------------------------------|
| A1040194 | <b><u>HWFRQ5SAR</u></b>   | 32 | <b>Reserve for HIF WLAN Firmware RX Queue 5 Start Address Register</b>  |
| A1040198 | <b><u>HWFRQ6SAR</u></b>   | 32 | <b>Reserved for HIF WLAN Firmware RX Queue 6 Start Address Register</b> |
| A104019C | <b><u>HWFRQ7SAR</u></b>   | 32 | <b>Reserved for HIF WLAN Firmware RX Queue 7 Start Address Register</b> |
| A10401A0 | <b><u>H2DRM0R</u></b>     | 32 | <b>Host to Device Receive Mailbox 0 Register</b>                        |
| A10401A4 | <b><u>H2DRM1R</u></b>     | 32 | <b>Host to Device Receive Mailbox 1 Register</b>                        |
| A10401A8 | <b><u>D2HSM0R</u></b>     | 32 | <b>Device to Host Send Mailbox 0 Register</b>                           |
| A10401AC | <b><u>D2HSM1R</u></b>     | 32 | <b>Device to Host Send Mailbox 1 Register</b>                           |
| A10401B0 | <b><u>D2HSM2R</u></b>     | 32 | <b>Device to Host Send Mailbox 2 Register</b>                           |
| A10401C0 | <b><u>HWRQ0CR</u></b>     | 32 | <b>HIF WLAN RX Queue 0 Control Register</b>                             |
| A10401C4 | <b><u>HWRQ1CR</u></b>     | 32 | <b>HIF WLAN RX Queue 1 Control Register</b>                             |
| A10401C8 | <b><u>HWRQ2CR</u></b>     | 32 | <b>HIF WLAN RX Queue 2 Control Register</b>                             |
| A10401CC | <b><u>HWRQ3CR</u></b>     | 32 | <b>HIF WLAN RX Queue 3 Control Register</b>                             |
| A10401D0 | <b><u>HWRQ4CR</u></b>     | 32 | <b>Reserved for HWRQ4CR</b>                                             |
| A10401D4 | <b><u>HWRQ5CR</u></b>     | 32 | <b>Reserved for HWRQ5CR</b>                                             |
| A10401D8 | <b><u>HWRQ6CR</u></b>     | 32 | <b>Reserved for HWRQ6CR</b>                                             |
| A10401DC | <b><u>HWRQ7CR</u></b>     | 32 | <b>Reserved for HWRQ7CR</b>                                             |
| A10401E0 | <b><u>HWRLFACR</u></b>    | 32 | <b>HIF WLAN RX Length FIFO Available Count Register</b>                 |
| A10401E4 | <b><u>HWRLFACR1</u></b>   | 32 | <b>Reserved for HWRLFACR1</b>                                           |
| A10401E8 | <b><u>HWDMACR</u></b>     | 32 | <b>HIF WLAN DMA Control Register</b>                                    |
| A10401EC | <b><u>HWFIOCDR</u></b>    | 32 | <b>HIF WLAN Firmware GPD IOC bit Disable Register</b>                   |
| A10401F0 | <b><u>HSDIOTOCR</u></b>   | 32 | <b>HIF SDIO Time-Out Control Register</b>                               |
| A1040200 | <b><u>HWFTSR0</u></b>     | 32 | <b>HIF WLAN Firmware TX Status Register 0</b>                           |
| A1040204 | <b><u>HWFTSR1</u></b>     | 32 | <b>HIF WLAN Firmware TX Status Register 1</b>                           |
| A1040210 | <b><u>HWDBGCR</u></b>     | 32 | <b>HIF WLAN Debug Control Register</b>                                  |
| A1040214 | <b><u>HWDBGPLR</u></b>    | 32 | <b>HIF WLAN Debug Packet Length Register</b>                            |
| A1040218 | <b><u>HSPICSR</u></b>     | 32 | <b>WLAN SPI Control Status Register (SPI Only)</b>                      |
| A1040220 | <b><u>HWRX0CGPD</u></b>   | 32 | <b>DMA RX0 Current GPD Address Register</b>                             |
| A1040224 | <b><u>HWRX1CGPD</u></b>   | 32 | <b>DMA RX1 Current GPD Address Register</b>                             |
| A1040228 | <b><u>HWRX2CGPD</u></b>   | 32 | <b>DMA RX2 Current GPD Address Register</b>                             |
| A104022C | <b><u>HWRX3CGPD</u></b>   | 32 | <b>DMA RX3 Current GPD Address Register</b>                             |
| A1040230 | <b><u>HWTX0CGPD</u></b>   | 32 | <b>DMA TX0 Current GPD Address Register</b>                             |
| A1040234 | <b><u>HWTX1Q1CGPD</u></b> | 32 | <b>DMA TX1 Que Type 1 Current GPD Address Register</b>                  |
| A1040238 | <b><u>HWTX1Q2CGPD</u></b> | 32 | <b>DMA TX1 Que Type 2 Current GPD Address Register</b>                  |
| A104023C | <b><u>HWTX1Q3CGPD</u></b> | 32 | <b>DMA TX1 Que Type 3 Current GPD Address Register</b>                  |
| A1040240 | <b><u>HWTX1Q4CGPD</u></b> | 32 | <b>DMA TX1 Que Type 4 Current GPD Address</b>                           |

|          |                                    | Register |                                                        |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----------|------------------------------------|----------|--------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|
| A1040244 | <u><a href="#">HWTX1Q5CGPD</a></u> | 32       | <b>DMA TX1 Que Type 5 Current GPD Address Register</b> |  |  |  |  |  |  |  |  |  |  |  |  |  |
| A1040248 | <u><a href="#">HWTX1Q6CGPD</a></u> | 32       | <b>DMA TX1 Que Type 6 Current GPD Address Register</b> |  |  |  |  |  |  |  |  |  |  |  |  |  |
| A104024C | <u><a href="#">HWTX1Q7CGPD</a></u> | 32       | <b>DMA TX1 Que Type 7 Current GPD Address Register</b> |  |  |  |  |  |  |  |  |  |  |  |  |  |
| A10403F4 | <u><a href="#">HSDIOCRCR</a></u>   | 32       | <b>HIF SDIO CRC status Register</b>                    |  |  |  |  |  |  |  |  |  |  |  |  |  |
| A10403F8 | <u><a href="#">HSDIORCR</a></u>    | 32       | <b>HIF SDIO Read Control Register</b>                  |  |  |  |  |  |  |  |  |  |  |  |  |  |

**A1040000 HGFCR****HIF Global Firmware Configuration Register****40020041**

| Bit   | 31 | 30                                         | 29                                          | 28                         | 27                          | 26                                 | 25                           | 24      | 23 | 22                   | 21              | 20             | 19 | 18                           | 17                                                 | 16                               |  |
|-------|----|--------------------------------------------|---------------------------------------------|----------------------------|-----------------------------|------------------------------------|------------------------------|---------|----|----------------------|-----------------|----------------|----|------------------------------|----------------------------------------------------|----------------------------------|--|
| Name  |    | SW_S<br>_S<br>EL_C<br>LK_N<br>LK_B<br>BL_C | PA_D<br>_ET<br>CR_C<br>LK_B<br>ON_Y<br>FW_C | PB_H<br>_CL<br>CR_K<br>DIS | EH_H<br>_HC<br>CL_LK<br>DIS | SPI_H<br>_CL<br>O_HC<br>LK_D<br>IS | SDI_O<br>_HC<br>LK_D<br>IS   |         |    |                      |                 |                |    | FO_H<br>_RC_E<br>_SD_H<br>_S | HC_LK_N_O_GA<br>_T_C_Y_M_TE<br>_ER_C_YC_M_AS<br>_K | INT_T<br>_ER_C<br>_YC_M<br>_AS_K |  |
| Type  |    | RW                                         | RW                                          | RW                         | RW                          | RW                                 | RW                           | RW      |    |                      |                 |                |    | RW                           | RW                                                 | RW                               |  |
| Reset |    | 1                                          | 0                                           | 0                          | 0                           | 0                                  | 0                            | 0       |    |                      |                 |                |    | 0                            | 1                                                  | 0                                |  |
| Bit   | 15 | 14                                         | 13                                          | 12                         | 11                          | 10                                 | 9                            | 8       | 7  | 6                    | 5               | 4              | 3  | 2                            | 1                                                  | 0                                |  |
| Name  |    |                                            |                                             |                            |                             | SD_CT_L_BU<br>SY                   | CA_IS_V<br>RD_FW_O<br>NT_S_B | HI_FW_B |    | SDI_O_PIO_S<br>_MO_E | EH_PI_MO<br>_DE | SPI_M_OD<br>_E |    | <b>DB_HIF_SEL</b>            |                                                    |                                  |  |
| Type  |    |                                            |                                             |                            |                             | RO                                 | RW                           | RW      |    | RO                   | RO              | RO             |    | RO                           |                                                    |                                  |  |
| Reset |    |                                            |                                             |                            |                             | 0                                  | 0                            | 0       |    | 1                    | 0               | 0              |    | 0                            | 0                                                  | 1                                |  |

| Bit(s) | Name              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30     | SW_SEL_CLKBLC     | <b>Software enables this bit to take over balance and non-balance SD clock control for pad macro. The need for non-balance SD clock for pad macro is due to tight output timing specifications. The default setting is controlled by hardware to decide the clock balance. However, software is flexible to determine the balance or non-balance clock tree for the SDIO pad macro.</b> <ul style="list-style-type: none"> <li>0: The balance/non-balance SD clock for pad macro is controlled by hardware.</li> <li>1: The balance/non-balance SD clock for pad macro is controlled by software.</li> </ul> |
| 29     | SW_SET_CLK_NONBLC | <b>Software enables this bit to use balance and non-balance SD clock for pad macro.</b> <ul style="list-style-type: none"> <li>0: Use balance SD clock for pad macro.</li> <li>1: Use non-balance SD clock for pad macro.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                         |
| 28     | PAD_CR_SET_BY_FW  | <b>Enable the pad macro control register test mode.</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

---

|    |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    |                  | <b>Firmware writes this bit and then gets the ownership to access the pad macro control registers.</b>                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 27 | PB_HCLK_DIS      | <ul style="list-style-type: none"> <li>• 0: Pad macro control register set by the host driver (normal mode).</li> <li>• 1: Pad macro control register set by the firmware (test mode).</li> </ul> <p><b>Used to disable the AHB clock for PIO-based function design. It is set when PIO-based function is not used in some specific configurations. Otherwise, the PIO-based function might fail.</b></p> <ul style="list-style-type: none"> <li>• 0: AHB clock is not disabled.</li> <li>• 1: Disable AHB clock.</li> </ul> |
| 26 | EHPI_HCLK_DIS    | <p><b>Used to disable the AHB clock for EHPI interface. It would be set when EHPI is not used in some specific configuration. Otherwise, the EHPI operation will fail.</b></p> <ul style="list-style-type: none"> <li>• 0: AHB clock is not disabled.</li> <li>• 1: Disable AHB clock.</li> </ul>                                                                                                                                                                                                                            |
| 25 | SPI_HCLK_DIS     | <p><b>Used to disable the AHB clock for SPI interface. It would be set when SPI is not used in some specific configurations. Otherwise, the SPI operation will fail.</b></p> <ul style="list-style-type: none"> <li>• 0: AHB clock is not disabled.</li> <li>• 1: Disable AHB clock.</li> </ul>                                                                                                                                                                                                                              |
| 24 | SDIO_HCLK_DIS    | <p><b>Used to disable the AHB clock for SDIO1 interface. It would be set when SDIO is not used in some specific configurations. Otherwise, the SDIO operation will fail.</b></p> <ul style="list-style-type: none"> <li>• 0: AHB clock is not disabled.</li> <li>• 1: Disable AHB clock.</li> </ul>                                                                                                                                                                                                                          |
| 18 | FORCE_SD_HS      | <p><b>Note, that the card can operate in high speed mode, using an external effuse or read or write interface to enable this function according to IP configuration.</b></p> <ul style="list-style-type: none"> <li>• 0: SDIO is in the operation mode specified in EHS of CCCR.</li> <li>• 1: FORCE SDIO to operate in high speed mode despite the values of EHS of CCCR.</li> </ul>                                                                                                                                        |
| 17 | HCLK_NO_GATED    | <ul style="list-style-type: none"> <li>• 0: SDIO controller would close some part of the AHB clock inside automatically for the unused period by the clock gating cell</li> <li>• 1: The AHB clock inside SDIO controller is always on.</li> </ul>                                                                                                                                                                                                                                                                           |
| 16 | INT_TER_CYC_MASK | <p><b>This field is used to determine whether SDIO should drive high to bus bit1 during the interrupt termination cycle.</b></p> <ul style="list-style-type: none"> <li>• 0 : always drive high during the termination cycle.</li> <li>• 1: drive high during the termination cycle only if it is in interrupt period.</li> </ul>                                                                                                                                                                                            |
| 10 | SDCTL_BUSY       | <p><b>Indicates whether SDIO controller is busy.</b></p> <ul style="list-style-type: none"> <li>• 0: SDIO controller is not busy.</li> <li>• 1: SDIO controller is still busy.</li> </ul>                                                                                                                                                                                                                                                                                                                                    |
| 9  | CARD_IS_18V      | <p><b>Firmware writes 1 to this field to show whether the voltage has switched and if the card is in 1.8V state.</b></p> <ul style="list-style-type: none"> <li>• 0: card is not in 1.8V state.</li> <li>• 1: card is in 1.8V state (UHS mode).</li> </ul>                                                                                                                                                                                                                                                                   |

---

|     |               |                                                                                                    |
|-----|---------------|----------------------------------------------------------------------------------------------------|
| 8   | HINT_AS_FW_OB | <b>Use an interrupt to host as a firmware ownership back control</b>                               |
| 6   | SDIO_PIO_SEL  | <b>Host interface for SDIO PIO-based function is used.</b>                                         |
| 5   | EHPI_MODE     | <b>This bit indicates if EHPI8-mode or EHPI16-mode is used.</b>                                    |
| 4   | SPI_MODE      | <b>This bit indicates if TI-mode or Motor-mode is used.</b>                                        |
| 2:0 | DB_HIF_SEL    | <b>Host interface for DMA-based function is used;</b><br>• 0x1: SDIO1<br>• 0x2: SPI<br>• 0x4: EHPI |

**A1040004 HGFISR****HIF Global Firmware Interrupt Status 00000000 Register**

| Bit           | 31 | 30 | 29 | 28 | 27                                 | 26                                 | 25                | 24                       | 23              | 22              | 21                     | 20                     | 19                         | 18                         | 17                         | 16                        |
|---------------|----|----|----|----|------------------------------------|------------------------------------|-------------------|--------------------------|-----------------|-----------------|------------------------|------------------------|----------------------------|----------------------------|----------------------------|---------------------------|
| <b>Name</b>   |    |    |    |    |                                    |                                    |                   |                          |                 |                 |                        |                        |                            |                            |                            |                           |
| <b>Type</b>   |    |    |    |    |                                    |                                    |                   |                          |                 |                 |                        |                        |                            |                            |                            |                           |
| <b>Rese t</b> |    |    |    |    |                                    |                                    |                   |                          |                 |                 |                        |                        |                            |                            |                            |                           |
| Bit           | 15 | 14 | 13 | 12 | 11                                 | 10                                 | 9                 | 8                        | 7               | 6               | 5                      | 4                      | 3                          | 2                          | 1                          | 0                         |
| <b>Name</b>   |    |    |    |    | <b>SD1_S ET_X TA_L RE_UP D INT</b> | <b>SD1_S ET_X TA_L RE_UP D INT</b> | <b>CH_G_TO_18</b> | <b>CR_C_ER_R_O_I_N T</b> | <b>PB_I_N T</b> | <b>DB_I_N T</b> | <b>SDI_O_SE_T_AB_T</b> | <b>SDI_O_SE_T_AB_T</b> | <b>DR_V_SE_T_P_B_I_O_E</b> | <b>DR_V_SE_T_P_B_I_O_E</b> | <b>DR_V_CL_R_P_B_I_O_E</b> | <b>DR_V_CL_R_DB_I_O_E</b> |
| <b>Type</b>   |    |    |    |    | W1_C                               | W1_C                               | W1_C              | RO                       | RO              | W1_C            | W1_C                   | W1_C                   | W1_C                       | W1_C                       | W1_C                       |                           |
| <b>Rese t</b> |    |    |    |    | 0                                  | 0                                  | 0                 | 0                        | 0               | 0               | 0                      | 0                      | 0                          | 0                          | 0                          |                           |

| Bit(s) | Name                 | Description                                                                                                                                                                                                                                                                       |
|--------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11     | SD1_SET_DS_INT       | <b>This bit is for SDIO interface only.</b><br>If the CCCR deep sleep register is set by host, this bit will be set, too. Once the firmware detects this event, it will set the device into deep sleep mode.<br>Firmware can clear this bit by writing 1. Writing 0 does nothing. |
| 10     | SD1_SET_XTAL_UPD_INT | <b>This bit is for SDIO interface only.</b><br>If the CCCR XTAL frequency update register is set in the host, this bit will be set, too. Once the firmware detects this event, it will                                                                                            |

|   |                    |                                                                                                                                                                                                                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
|   |                    | know that the host has updated the XTAL frequency. Firmware can then read HGH2DR to find the updated frequency value.                                                                                                         |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 9 | CHG_TO_18V_REQ_INT | Firmware can clear this bit by writing 1. Writing 0 does nothing.                                                                                                                                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 8 | CRC_ERROR_INT      | <b>Host sends command 11 to request the device to change the voltage to 1.8V. Firmware receives the interrupt or polling status to switch the voltage. Then the firmware writes that the card is in 1.8V status to HGFCR.</b> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 7 | PB_INT             | <b>The status bit of TX data port CRC error interrupt.</b>                                                                                                                                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 6 | DB_INT             | <b>The status bit of PIO-based function firmware interrupt.</b>                                                                                                                                                               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 5 | SDIO_SET_ABT       | <b>SDIO writes 1 to SDIO CCCR. ABORT to abort the transaction. Once the firmware detects this event, the TX and RX queues are stopped and the data in the buffer is discarded.</b>                                            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 4 | SDIO_SET_RES       | Firmware can clear this bit by writing 1. Writing 0 does nothing.                                                                                                                                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 3 | DRV_SET_PB_IOE     | <b>SDIO writes 1 to SDIO CCCR.RES to assert software reset. Once the firmware detects this event, it disables the sub-systems on SDIO interface.</b>                                                                          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 2 | DRV_SET_DB_IOE     | Firmware can clear this bit by writing 1. Writing 0 does nothing.                                                                                                                                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1 | DRV_CLR_PB_IOE     | <b>This bit is for SDIO interface only.</b>                                                                                                                                                                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0 | DRV_CLR_DB_IOE     | This bit is set if the host sets the CCCR.IOE bit of PIO-based functional block. Once the firmware detects this event, it enables the sub-system that uses PIO-based function.                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                    | Firmware can clear this bit by writing 1. Writing 0 does nothing.                                                                                                                                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                    | <b>This bit is for SDIO interface only.</b>                                                                                                                                                                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                    | This bit is set if the host sets the CCCR.IOE bit of DMA-based functional block. Once the firmware detects this event, it enables the sub-system that uses DMA-based function.                                                |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                    | Firmware can clear this bit by writing 1. Writing 0 does nothing.                                                                                                                                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                    | <b>This bit is for SDIO interface only.</b>                                                                                                                                                                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                    | This bit is set if the host clears the CCCR.IOE bit of PIO-based functional block. Once the firmware detects this event, it disables the sub-system that uses PIO-based function.                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                    | Firmware can clear this bit by writing 1. Writing 0 does nothing.                                                                                                                                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                    | <b>This bit is for SDIO interface only.</b>                                                                                                                                                                                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                    | This bit is set if the host clears the CCCR.IOE bit of DMA-based functional block. Once the firmware detects this event, it disables the sub-system which uses DMA-based function.                                            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |                    | Firmware can clear this bit by writing 1. Writing 0 does nothing.                                                                                                                                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

**A1040008 HGFIER****HIF Global Firmware Interrupt Enable 00000000 Register**

| Bit    | 31 | 30 | 29 | 28 | 27           | 26           | 25           | 24          | 23          | 22          | 21           | 20           | 19          | 18          | 17          | 16          |
|--------|----|----|----|----|--------------|--------------|--------------|-------------|-------------|-------------|--------------|--------------|-------------|-------------|-------------|-------------|
| Name   |    |    |    |    |              |              |              |             |             |             |              |              |             |             |             |             |
| Type   |    |    |    |    |              |              |              |             |             |             |              |              |             |             |             |             |
| Rese t |    |    |    |    |              |              |              |             |             |             |              |              |             |             |             |             |
| Bit    | 15 | 14 | 13 | 12 | 11           | 10           | 9            | 8           | 7           | 6           | 5            | 4            | 3           | 2           | 1           | 0           |
| Name   |    |    |    |    | <b>SD1_S</b> | <b>SD1_S</b> | <b>CH_G</b>  | <b>CR_C</b> | <b>PB_I</b> | <b>DB_N</b> | <b>SDI_O</b> | <b>SDI_O</b> | <b>DR_V</b> | <b>DR_V</b> | <b>DR_V</b> | <b>DR_V</b> |
|        |    |    |    |    | <b>ET_D</b>  | <b>ET_X</b>  | <b>TO_R</b>  | <b>ER_E</b> | <b>NT_E</b> | <b>I_N</b>  | <b>NT_SE</b> | <b>NT_SE</b> | <b>V_SE</b> | <b>V_SE</b> | <b>CL_R</b> | <b>CL_R</b> |
|        |    |    |    |    | <b>S_I</b>   | <b>TA_V</b>  | <b>-18_R</b> | <b>RO_I</b> | <b>N_N</b>  | <b>AB_N</b> | <b>T_AB</b>  | <b>T_AB</b>  | <b>PB_T</b> | <b>DB_T</b> | <b>DB_T</b> | <b>DB_R</b> |

|           |                         |                                                                                                                                                         |  |  | NT<br>E<br>N | L<br>UP<br>D<br>INT<br>E<br>N | RE<br>Q_I<br>NT<br>E<br>N | NT<br>E<br>N |    |    | T_I<br>NT<br>E<br>N | S_I<br>NT<br>E<br>N | IO<br>E_I<br>NT<br>E<br>N | IO<br>E_I<br>NT<br>E<br>N | IO<br>E_I<br>NT<br>E<br>N |
|-----------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--------------|-------------------------------|---------------------------|--------------|----|----|---------------------|---------------------|---------------------------|---------------------------|---------------------------|
| Type      |                         |                                                                                                                                                         |  |  | RW           | RW                            | RW                        | RW           | RW | RW | RW                  | RW                  | RW                        | RW                        | RW                        |
| Rese<br>t |                         |                                                                                                                                                         |  |  | o            | o                             | o                         | o            | o  | o  | o                   | o                   | o                         | o                         | o                         |
| 11        | SD1_SET_DS_INT_EN       | <b>Common firmware interrupt output control for each bit corresponding to bits defined in HGFISR.</b>                                                   |  |  |              |                               |                           |              |    |    |                     |                     |                           |                           |                           |
|           |                         | If the related bit is                                                                                                                                   |  |  |              |                               |                           |              |    |    |                     |                     |                           |                           |                           |
|           |                         | <ul style="list-style-type: none"> <li>• o: Disable the related bit interrupt output.</li> <li>• 1: Enable the related bit interrupt output.</li> </ul> |  |  |              |                               |                           |              |    |    |                     |                     |                           |                           |                           |
| 10        | SD1_SET_XTAL_UPD_INT_EN | <b>Common firmware interrupt output control for each bit corresponding to bits defined in HGFISR.</b>                                                   |  |  |              |                               |                           |              |    |    |                     |                     |                           |                           |                           |
|           |                         | If the related bit is                                                                                                                                   |  |  |              |                               |                           |              |    |    |                     |                     |                           |                           |                           |
|           |                         | <ul style="list-style-type: none"> <li>• o: Disable the related bit interrupt output.</li> <li>• 1: Enable the related bit interrupt output.</li> </ul> |  |  |              |                               |                           |              |    |    |                     |                     |                           |                           |                           |
| 9         | CHG_TO_18V_REQ_INT_EN   | <b>Common firmware interrupt output control for each bit corresponding to bits defined in HGFISR.</b>                                                   |  |  |              |                               |                           |              |    |    |                     |                     |                           |                           |                           |
|           |                         | If the related bit is                                                                                                                                   |  |  |              |                               |                           |              |    |    |                     |                     |                           |                           |                           |
|           |                         | <ul style="list-style-type: none"> <li>• o: Disable the related bit interrupt output.</li> <li>• 1: Enable the related bit interrupt output.</li> </ul> |  |  |              |                               |                           |              |    |    |                     |                     |                           |                           |                           |
| 8         | CRC_ERROR_INT_EN        | <b>Common firmware interrupt output control for each bit corresponding to bits defined in HGFISR.</b>                                                   |  |  |              |                               |                           |              |    |    |                     |                     |                           |                           |                           |
|           |                         | If the related bit is                                                                                                                                   |  |  |              |                               |                           |              |    |    |                     |                     |                           |                           |                           |
|           |                         | <ul style="list-style-type: none"> <li>• o: Disable the related bit interrupt output.</li> <li>• 1: Enable the related bit interrupt output.</li> </ul> |  |  |              |                               |                           |              |    |    |                     |                     |                           |                           |                           |
| 7         | PB_INT_EN               | <b>Common firmware interrupt output control for each bit corresponding to bits defined in HGFISR.</b>                                                   |  |  |              |                               |                           |              |    |    |                     |                     |                           |                           |                           |
|           |                         | If the related bit is                                                                                                                                   |  |  |              |                               |                           |              |    |    |                     |                     |                           |                           |                           |
|           |                         | <ul style="list-style-type: none"> <li>• o: Disable the related bit interrupt output.</li> <li>• 1: Enable the related bit interrupt output.</li> </ul> |  |  |              |                               |                           |              |    |    |                     |                     |                           |                           |                           |
| 6         | DB_INT_EN               | <b>Common firmware interrupt output control for each bit corresponding to bits defined in HGFISR.</b>                                                   |  |  |              |                               |                           |              |    |    |                     |                     |                           |                           |                           |
|           |                         | If the related bit is                                                                                                                                   |  |  |              |                               |                           |              |    |    |                     |                     |                           |                           |                           |
|           |                         | <ul style="list-style-type: none"> <li>• o: Disable the related bit interrupt output.</li> <li>• 1: Enable the related bit interrupt output.</li> </ul> |  |  |              |                               |                           |              |    |    |                     |                     |                           |                           |                           |
| 5         | SDIO_SET_ABT_INT_EN     | <b>Common firmware interrupt output control for each bit corresponding to bits defined in HGFISR.</b>                                                   |  |  |              |                               |                           |              |    |    |                     |                     |                           |                           |                           |
|           |                         | If the related bit is                                                                                                                                   |  |  |              |                               |                           |              |    |    |                     |                     |                           |                           |                           |
|           |                         | <ul style="list-style-type: none"> <li>• o: Disable the related bit interrupt output.</li> <li>• 1: Enable the related bit interrupt output.</li> </ul> |  |  |              |                               |                           |              |    |    |                     |                     |                           |                           |                           |
| 4         | SDIO_SET_RES_INT_EN     | <b>Common firmware interrupt output control for each bit corresponding to bits defined in HGFISR.</b>                                                   |  |  |              |                               |                           |              |    |    |                     |                     |                           |                           |                           |
|           |                         | If the related bit is                                                                                                                                   |  |  |              |                               |                           |              |    |    |                     |                     |                           |                           |                           |

---

3      DRV\_SET\_PB\_IOE\_INT\_EN

- 0: Disable the related bit interrupt output.
- 1: Enable the related bit interrupt output.

2      DRV\_SET\_DB\_IOE\_INT\_EN

**Common firmware interrupt output control for each bit corresponding to bits defined in HGFISR.**

If the related bit is

- 0: Disable the related bit interrupt output.
- 1: Enable the related bit interrupt output.

1      DRV\_CLR\_PB\_IOE\_INT\_EN

**Common firmware interrupt output control for each bit corresponding to bits defined in HGFISR.**

If the related bit is

- 0: Disable the related bit interrupt output.
- 1: Enable the related bit interrupt output.

0      DRV\_CLR\_DB\_IOE\_INT\_EN

**Common firmware interrupt output control for each bit corresponding to bits defined in HGFISR.**

If the related bit is

- 0: Disable the related bit interrupt output.
- 1: Enable the related bit interrupt output.

**Common firmware interrupt output control for each bit corresponding to bits defined in HGFISR.**

If the related bit is

- 0: Disable the related bit interrupt output.
  - 1: Enable the related bit interrupt output.
- 

### A1040010 HSDBDLSR

### HIF SDIO Bus Delay Selection Register 00000000

| Bit   | 31 | 30               | 29 | 28 | 27 | 26               | 25 | 24 | 23 | 22               | 21 | 20 | 19 | 18               | 17 | 16 |
|-------|----|------------------|----|----|----|------------------|----|----|----|------------------|----|----|----|------------------|----|----|
| Name  |    |                  |    |    |    |                  |    |    |    |                  |    |    |    |                  |    |    |
| Type  |    |                  |    |    |    |                  |    |    |    |                  |    |    |    |                  |    |    |
| Reset |    |                  |    |    |    |                  |    |    |    |                  |    |    |    |                  |    |    |
| Bit   | 15 | 14               | 13 | 12 | 11 | 10               | 9  | 8  | 7  | 6                | 5  | 4  | 3  | 2                | 1  | 0  |
| Name  |    | SD1_DAT3_DEL SEL |    |    |    | SD1_DAT2_DEL SEL |    |    |    | SD1_DAT1_DEL SEL |    |    |    | SD1_DATO_DEL SEL |    |    |
| Type  |    | RW               |    |    |
| Reset |    | 0                | 0  | 0  |    | 0                | 0  | 0  |    | 0                | 0  | 0  |    | 0                | 0  | 0  |

#### Bit(s) Name

14:12     SD1\_DAT3\_DELSEL

#### Description

**It is used to tune the SDIO1 bit3 bus delay for desensitization**

- 7: about 1.4ns.
  - 6: about 1.2ns.
  - 5: about 1.0ns.
  - 4: about 0.8ns.
  - 3: about 0.6ns.
  - 2: about 0.4ns.
  - 1: about 0.2ns.
-

|      |                 |                                                                                                                                                                                                                                                                                                                                                                                                           |
|------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10:8 | SD1_DAT2_DELSEL | <ul style="list-style-type: none"><li>• 0: no delay.</li></ul> <p><b>It is used to tune the SDIO1 bit2 bus delay for desensitization (bit 2)</b></p> <ul style="list-style-type: none"><li>• 7: about 1.4ns.</li><li>• 6: about 1.2ns.</li><li>• 5: about 1.0ns.</li><li>• 4: about 0.8ns.</li><li>• 3: about 0.6ns.</li><li>• 2: about 0.4ns.</li><li>• 1: about 0.2ns.</li><li>• 0: no delay.</li></ul> |
| 6:4  | SD1_DAT1_DELSEL | <p><b>It is used to tune the SDIO1 bit1 bus delay for desensitization</b></p> <ul style="list-style-type: none"><li>• 7: about 1.4ns.</li><li>• 6: about 1.2ns.</li><li>• 5: about 1.0ns.</li><li>• 4: about 0.8ns.</li><li>• 3: about 0.6ns.</li><li>• 2: about 0.4ns.</li><li>• 1: about 0.2ns.</li><li>• 0: no delay</li></ul>                                                                         |
| 2:0  | SD1_DATO_DELSEL | <p><b>It is used to tune the SDIO1 bit0 bus delay for desensitization</b></p> <ul style="list-style-type: none"><li>• 7: about 1.4ns.</li><li>• 6: about 1.2ns.</li><li>• 5: about 1.0ns</li><li>• 4: about 0.8ns</li><li>• 3: about 0.6ns.</li><li>• 2: about 0.4ns.</li><li>• 1: about 0.2ns.</li><li>• 0: no delay</li></ul>                                                                           |

| A1040014 |    | HIF SRAM Delay Selection Register |    |    |                   |                   |    |    |    |    |    |    |                   | 00000FoA          |    |    |  |
|----------|----|-----------------------------------|----|----|-------------------|-------------------|----|----|----|----|----|----|-------------------|-------------------|----|----|--|
| Bit      | 31 | 30                                | 29 | 28 | 27                | 26                | 25 | 24 | 23 | 22 | 21 | 20 | 19                | 18                | 17 | 16 |  |
| Name     |    |                                   |    |    |                   |                   |    |    |    |    |    |    |                   |                   |    |    |  |
| Type     |    |                                   |    |    |                   |                   |    |    |    |    |    |    |                   |                   |    |    |  |
| Reset    |    |                                   |    |    |                   |                   |    |    |    |    |    |    |                   |                   |    |    |  |
| Bit      | 15 | 14                                | 13 | 12 | 11                | 10                | 9  | 8  | 7  | 6  | 5  | 4  | 3                 | 2                 | 1  | 0  |  |
| Name     |    |                                   |    |    | PB_DELS<br>EL_3_2 | PB_DELS<br>EL_1_0 |    |    |    |    |    |    | DB_DELS<br>EL_3_2 | DB_DELS<br>EL_1_0 |    |    |  |
| Type     |    |                                   |    |    | RW                | RW                |    |    |    |    |    |    | RW                | RW                |    |    |  |
| Reset    |    |                                   |    |    | 1                 | 1                 | 1  | 1  |    |    |    |    | 1                 | 0                 | 1  | 0  |  |

| <b>Bit(s)</b> | <b>Name</b>   | <b>Description</b>                                                                                                                        |
|---------------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 11:10         | PB_DELSEL_3_2 | <b>Delay selection of SRAM of PIO-based part of SDIO controller</b><br>Note, that the default value is different for different processes. |
| 9:8           | PB_DELSEL_1_0 | <b>Delay selection of SRAM of PIO-based part of SDIO controller</b><br>Note, that the default value is different for different processes. |
| 3:2           | DB_DELSEL_3_2 | <b>Delay selection of SRAM of DMA-based part of SDIO controller</b><br>Note, that the default value is different for different processes. |
| 1:0           | DB_DELSEL_1_0 | <b>Delay selection of SRAM of DMA-based part of SDIO controller</b><br>Note, that the default value is different for different processes. |

| <b>A1040018 HCSDCR</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>HIF Clock Stop Detection register</b> |                       |  |  |
|------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------------------------------|-----------------------|--|--|
| <b>Bit</b>             | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                                       |                       |  |  |
| <b>Name</b>            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                          | <b>SDCLK_STOP_NUM</b> |  |  |
| <b>Type</b>            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                          | <b>RW</b>             |  |  |
| <b>Reset</b>           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                          | 0 0 0 0               |  |  |
| <b>Bit</b>             | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                                        |                       |  |  |
| <b>Name</b>            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                          | <b>SDCLK_STOP_NUM</b> |  |  |
| <b>Type</b>            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                          | <b>RW</b>             |  |  |
| <b>Reset</b>           | 1  | 1  | 1  | 1  | 1  | 1  | 0  | 1  | 1  | 1  | 1  | 0  | 1  | 0  | 0  | 0                                        |                       |  |  |

| <b>Bit(s)</b> | <b>Name</b>    | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19:0          | SDCLK_STOP_NUM | For SDIO 3.0 design, host driver needs to issue CMD11 to switch the voltage to 1.8V to enter UHS mode. This field is to set the hardware timer threshold for SDIO hardware to determine whether the SD clock has stopped. According to SDIO 3.0 specifications, the host should stop the clock at least 5ms for the device to switch the voltage from 3.3V to 1.8V. The unit of this field is based on the AHB clock cycle number. |

| <b>A104001C HGH2DR</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>HIF Global Host to Device Register</b> |                  |  |  |
|------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------------------------------|------------------|--|--|
| <b>Bit</b>             | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                                        |                  |  |  |
| <b>Name</b>            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                           |                  |  |  |
| <b>Type</b>            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                           |                  |  |  |
| <b>Reset</b>           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                           |                  |  |  |
| <b>Bit</b>             | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                                         |                  |  |  |
| <b>Name</b>            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                           | <b>XTAL_FREQ</b> |  |  |
| <b>Type</b>            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                           | <b>RO</b>        |  |  |
| <b>Reset</b>           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                           | 0 1 1            |  |  |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b> |
|---------------|-------------|--------------------|
|---------------|-------------|--------------------|

|     |           |                                                                                                                                                                                                                                                                                                                                                           |
|-----|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0 | XTAL_FREQ | The host can write this CCCR vendor unique register to update the XTAL frequency information for firmware to read. When the host writes 1 to this field, hardware would send an interrupt to firmware to notify that the host has updated the XTAL frequency. Firmware can read the firmware domain HGH2DR register to derive the updated XTAL frequency. |
|-----|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

| <b>A1040020 HDBGCR</b> |                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>HIF Debug Control Register</b> |                   |   |   |   |   |   |   | <b>11110000</b> |  |  |  |  |  |  |  |
|------------------------|-------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------------|-------------------|---|---|---|---|---|---|-----------------|--|--|--|--|--|--|--|
| <b>Bit</b>             | 31                | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                                |                   |   |   |   |   |   |   |                 |  |  |  |  |  |  |  |
| <b>Name</b>            | <b>DEBUG_MONH</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                   | <b>DEBUG_MONL</b> |   |   |   |   |   |   |                 |  |  |  |  |  |  |  |
| <b>Type</b>            | RO                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                   | RO                |   |   |   |   |   |   |                 |  |  |  |  |  |  |  |
| <b>Reset</b>           | 0                 | 0  | 0  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 1                                 | 0                 | 0 | 0 | 0 | 0 | 0 | 0 | 0               |  |  |  |  |  |  |  |
| <b>Bit</b>             | 15                | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                                 |                   |   |   |   |   |   |   |                 |  |  |  |  |  |  |  |
| <b>Name</b>            | <b>FLAG_HSEL</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                   | <b>FLAG_LSEL</b>  |   |   |   |   |   |   |                 |  |  |  |  |  |  |  |
| <b>Type</b>            | RW                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                   | RW                |   |   |   |   |   |   |                 |  |  |  |  |  |  |  |
| <b>Reset</b>           | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                                 | 0                 | 0 | 0 | 0 | 0 | 0 | 0 | 0               |  |  |  |  |  |  |  |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                                                    |
|---------------|-------------|---------------------------------------------------------------------------------------|
| 31:24         | DEBUG_MONH  | <b>Debug flag monitor for High byte</b><br>Show the flag value specified in FLAG_HSEL |
| 23:16         | DEBUG_MONL  | <b>Debug flag monitor for Low byte</b><br>Show the flag value specified in FLAG_LSEL  |
| 15:8          | FLAG_HSEL   | <b>Flag number of High byte for debug</b><br>Select which flag for debug in high byte |
| 7:0           | FLAG_LSEL   | <b>Flag number of Low byte for debug</b><br>Select which flag for debug in low byte   |

| <b>A104002C FWDSIOCR</b> |                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>DS Pad Macro IO Control Register</b> |                 |               |              |              |              |              |    | <b>80000422</b> |  |  |  |  |  |  |  |
|--------------------------|------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------------------------|-----------------|---------------|--------------|--------------|--------------|--------------|----|-----------------|--|--|--|--|--|--|--|
| <b>Bit</b>               | 31               | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                                      |                 |               |              |              |              |              |    |                 |  |  |  |  |  |  |  |
| <b>Name</b>              | <b>DS_RDSEL</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                         | <b>DS_TDSEL</b> |               |              |              |              |              |    |                 |  |  |  |  |  |  |  |
| <b>Type</b>              | RW               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                         | RW              |               |              |              |              |              |    |                 |  |  |  |  |  |  |  |
| <b>Reset</b>             | 1                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                         | 0               |               |              |              |              |              |    |                 |  |  |  |  |  |  |  |
| <b>Bit</b>               | 15               | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                                       |                 |               |              |              |              |              |    |                 |  |  |  |  |  |  |  |
| <b>Name</b>              | <b>DS_E8E4E2</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                         | <b>DS_SMT</b>   | <b>DS_UPD</b> | <b>DS_R1</b> | <b>DS_RO</b> | <b>DS_ES</b> | <b>DS_SR</b> |    |                 |  |  |  |  |  |  |  |
| <b>Type</b>              | RW               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                         | RW              | RW            | RW           | RW           | RW           | RW           | RW | RW              |  |  |  |  |  |  |  |
| <b>Reset</b>             | 1                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                         | 1               | 0             | 0            | 0            | 0            | 1            | 0  |                 |  |  |  |  |  |  |  |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                                              |
|---------------|-------------|---------------------------------------------------------------------------------|
| 31            | DS_RESP_EN  | <b>HS400 mode response ds toggle enable bit</b><br>0:response DS toggle disable |

| Bit(s) | Name      | Description                                                                                                                                                                                                                                                                                                                                                                                 |
|--------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29:24  | DS_RDSEL  | 1: response DS toggle enable<br><b>RX duty select</b><br>RDSEL[1:0]: Input buffer duty high when asserted (high pulse width adjustment)<br>RDSEL[3:2]: Input buffer duty low when asserted (low pulse width adjustment)<br>RDSEL[5:4]: Level shifter duty high when asserted (high pulse width adjustment)<br>RDSEL[7:6]: Level shifter duty low when asserted (low pulse width adjustment) |
| 19:16  | DS_TDSEL  | <b>TX duty select</b><br>TDSEL[1:0]: Output level shifter duty high when asserted (high pulse width adjustment)<br>TDSEL[3:2]: Output level shifter duty low when asserted (low pulse width adjustment)                                                                                                                                                                                     |
| 10:8   | DS_E8E4E2 | <b>TX Driving Strength Control.</b>                                                                                                                                                                                                                                                                                                                                                         |
| 5      | DS_SMT    | <b>RX input buffer Schmitt trigger hysteresis control enable. High asserted.</b>                                                                                                                                                                                                                                                                                                            |
| 4      | DS_PUPD   | SMT=1, Schmitt Trigger enable<br><b>Pull-up / pull-down selection.</b><br>0: pull-up resistor<br>1: pull-down resistor<br>CLK pad default no pull                                                                                                                                                                                                                                           |
| 3      | DS_R1     | <b>Select 50K resistor (0: not select, 1: select)</b>                                                                                                                                                                                                                                                                                                                                       |
| 2      | DS_R0     | <b>Select 10K resistor (0: not select, 1: select)</b>                                                                                                                                                                                                                                                                                                                                       |
| 1      | DSIES     | <b>RX input buffer enable. High asserted.</b><br>Datapath: from IO to O. IES=0, O=0                                                                                                                                                                                                                                                                                                         |
| 0      | DS_SR     | <b>Output Slew Rate Control. High asserted.</b><br>SR=1, slower slew.<br>SR=0, no slew rate controlled.                                                                                                                                                                                                                                                                                     |

| A1040030 HGTMTCR Test Mode Trigger Control Register 00001300 |    |    |    |                     |    |               |    |    |    |    |    |    |    |           |           |    |
|--------------------------------------------------------------|----|----|----|---------------------|----|---------------|----|----|----|----|----|----|----|-----------|-----------|----|
| Bit                                                          | 31 | 30 | 29 | 28                  | 27 | 26            | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18        | 17        | 16 |
| <b>Name</b>                                                  |    |    |    |                     |    |               |    |    |    |    |    |    |    |           |           |    |
| <b>Type</b>                                                  |    |    |    |                     |    |               |    |    |    |    |    |    |    |           |           |    |
| <b>Rese t</b>                                                |    |    |    |                     |    |               |    |    |    |    |    |    |    |           |           |    |
| Bit                                                          | 15 | 14 | 13 | 12                  | 11 | 10            | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2         | 1         | 0  |
| <b>Name</b>                                                  |    |    |    | <b>TM_BUS_WIDTH</b> |    | <b>TM_BSS</b> |    |    |    |    |    |    |    | <b>FW</b> | <b>FW</b> |    |
|                                                              |    |    |    |                     |    |               |    |    |    |    |    |    |    | <b>T</b>  | <b>T</b>  |    |
|                                                              |    |    |    |                     |    |               |    |    |    |    |    |    |    | <b>RI</b> | <b>RI</b> |    |
|                                                              |    |    |    |                     |    |               |    |    |    |    |    |    |    | <b>GG</b> | <b>GG</b> |    |
|                                                              |    |    |    |                     |    |               |    |    |    |    |    |    |    | <b>ER</b> | <b>ER</b> |    |
|                                                              |    |    |    |                     |    |               |    |    |    |    |    |    |    | <b>C</b>  | <b>T</b>  |    |
|                                                              |    |    |    |                     |    |               |    |    |    |    |    |    |    | <b>RC</b> | <b>M</b>  |    |
|                                                              |    |    |    |                     |    |               |    |    |    |    |    |    |    | <b>S</b>  | <b>DA</b> |    |
|                                                              |    |    |    |                     |    |               |    |    |    |    |    |    |    | <b>TS</b> | <b>TA</b> |    |
| <b>Type</b>                                                  |    |    |    | RW                  |    | RW            |    |    |    |    |    |    |    | RW        | RW        |    |
| <b>Rese t</b>                                                |    |    |    | 1                   | 0  | 0             | 1  | 1  |    |    |    |    |    | 0         | 0         |    |

| Bit(s) | Name         | Description                                                                                                                    |
|--------|--------------|--------------------------------------------------------------------------------------------------------------------------------|
| 12:11  | TM_BUS_WIDTH | <b>For Test Mode, set the bus width of SDIO bus interface</b><br>0x0: SD1-bit<br>0x1: Reserved<br>0x2: SD4-bit<br>0x3: SD8-bit |
| 10:8   | TM_BSS       | <b>For Test Mode, set the bus speed of SDIO bus interface</b>                                                                  |

| Bit(s) | Name               | Description                                                                                                                                                                                                                                                                                                                                                                                     |
|--------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1      | FW_TRIGGER_CRC_STS | <p>ox0: SDR12<br/>ox1: SDR25<br/>ox2: SDR50<br/>ox3: SDR104<br/>ox4: DDR50</p> <p><b>For Test Mode:</b> Send a good CRC status after firmware trigger is enabled. The firmware polls this bit to make it 0 to trigger another event.</p> <p>0: Disable SDIO Device Send CRC Status<br/>1: Enable SDIO Device Send CRC Status</p>                                                                |
| 0      | FW_TRIGGER_TM_DATA | <p><b>For the Test Mode:</b> Send a specific response and block data after firmware trigger is enabled. The firmware polls this bit to make it 0 to trigger another event.</p> <p>Note, that the content is configured similar to the host initiated pattern generation</p> <p>0: Disable SDIO Device Send Response and block data.<br/>1: Enable SDIO Device Send Response and block data.</p> |

| A1040034 HGTMCR |    |    |    |    |    |    |    | Test Mode Control Register                  |               |    |    |    |    |    |    | 00080000 |                  |   |  |  |  |  |  |  |  |
|-----------------|----|----|----|----|----|----|----|---------------------------------------------|---------------|----|----|----|----|----|----|----------|------------------|---|--|--|--|--|--|--|--|
| Bit             | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24                                          | 23            | 22 | 21 | 20 | 19 | 18 | 17 | 16       |                  |   |  |  |  |  |  |  |  |
| Name            |    |    |    |    |    |    |    | TE<br>ST<br>_M<br>OD<br>E<br>FW<br>_O<br>WN | PRBS_INIT_VAL |    |    |    |    |    |    |          |                  |   |  |  |  |  |  |  |  |
| Type            |    |    |    |    |    |    |    | RW                                          | RW            |    |    |    |    |    |    |          |                  |   |  |  |  |  |  |  |  |
| Reset           |    |    |    |    |    |    |    | o                                           | o             | o  | o  | o  | 1  | o  | o  | o        |                  |   |  |  |  |  |  |  |  |
| Bit             | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8                                           | 7             | 6  | 5  | 4  | 3  | 2  | 1  | 0        |                  |   |  |  |  |  |  |  |  |
| Name            |    |    |    |    |    |    |    | TE<br>ST<br>_M<br>OD<br>E<br>ST<br>AT<br>US |               |    |    |    |    |    |    |          | TEST_MODE_SELECT |   |  |  |  |  |  |  |  |
| Type            |    |    |    |    |    |    |    | RO                                          |               |    |    |    |    |    |    |          | RW               |   |  |  |  |  |  |  |  |
| Reset           |    |    |    |    |    |    |    | o                                           |               |    |    |    |    |    |    |          | o                | o |  |  |  |  |  |  |  |

| Bit(s) | Name             | Description                                                                                                                                                          |
|--------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24     | TEST_MODE_FW_OWN | Indicates the ownership of Test Mode Control Register : WTMCR,WTMDPCR0,WTMDPCR1<br>0: Host has the ownership.<br>1: Firmware has the ownership.                      |
| 23:16  | PRBS_INIT_VAL    | <b>Initial Value For PRBS generator</b>                                                                                                                              |
| 8      | TEST_MODE_STATUS | To record the comparison result of the latest Test Mode write operation.<br>0: Data compare of Test Mode write is Pass<br>1: Data compare of Test Mode write is Fail |
| 1:0    | TEST_MODE_SELECT | <b>Select the test mode data pattern</b><br>-64-bits configurable data register (WTMDPCR0:WTMDPCR1)<br>-32-bits configurable data register                           |

| Bit(s) | Name | Description                                                                                           |
|--------|------|-------------------------------------------------------------------------------------------------------|
| -PRBS  |      | 00: the 32bit data pattern<br>01: the 64bit data pattern<br>10: the PRBS data pattern<br>11: reserved |

**A1040038 HGTMDPCRo** **Test Mode Data Pattern Control Register 0** **FoFoFoFo**

| Bit   | 31                              | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|---------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | <b>TEST_MODE_DATA_PATTERN_0</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 1                               | 1  | 1  | 1  | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | 0  | 0  | 0  | 0  |
| Bit   | 15                              | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>TEST_MODE_DATA_PATTERN_0</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 1                               | 1  | 1  | 1  | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | 0  | 0  | 0  | 0  |

| Bit(s) | Name                     | Description                     |
|--------|--------------------------|---------------------------------|
| 31:0   | TEST_MODE_DATA_PATTERN_0 | Data pattern for Test Mode read |

**A104003C HGTMDPCR1** **Test Mode Data Pattern Control Register 1** **FoFoFoFo**

| Bit   | 31                              | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|---------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | <b>TEST_MODE_DATA_PATTERN_1</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 1                               | 1  | 1  | 1  | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | 0  | 0  | 0  | 0  |
| Bit   | 15                              | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>TEST_MODE_DATA_PATTERN_1</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 1                               | 1  | 1  | 1  | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | 0  | 0  | 0  | 0  |

| Bit(s) | Name                     | Description                      |
|--------|--------------------------|----------------------------------|
| 31:0   | TEST_MODE_DATA_PATTERN_1 | Data pattern for Test Mode write |

**A1040040 FWCLKIOCR T28LP** **Clock Pad Macro IO Control Register** **00000422**

| Bit   | 31                | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|-------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | <b>CLK_RDSEL</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15                | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>CLK_E8E4E2</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| e      |  |  |  |  |   |    |   |  |    | K_SMT | K_PUD | K_R1 | K_Ro | K_IES | K_SR |
|--------|--|--|--|--|---|----|---|--|----|-------|-------|------|------|-------|------|
| Type   |  |  |  |  |   | RW |   |  | RW | RW    | RW    | RW   | RW   | RW    |      |
| Rese t |  |  |  |  | 1 | 0  | 0 |  |    | 1     | 0     | 0    | 0    | 1     | 0    |

| Bit(s) | Name       | Description                                                                                                                                                                                                                                                                                                                                                 |
|--------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29:24  | CLK_RDSEL  | <b>RX duty select</b><br>RDSEL[1:0]: Input buffer duty high when asserted (high pulse width adjustment)<br>RDSEL[3:2]: Input buffer duty low when asserted (low pulse width adjustment)<br>RDSEL[5:4]: Level shifter duty high when asserted (high pulse width adjustment)<br>RDSEL[7:6]: Level shifter duty low when asserted (low pulse width adjustment) |
| 19:16  | CLK_TDSEL  | <b>TX duty select</b><br>TDSEL[1:0]: Output level shifter duty high when asserted (high pulse width adjustment)<br>TDSEL[3:2]: Output level shifter duty low when asserted (low pulse width adjustment)                                                                                                                                                     |
| 10:8   | CLK_E8E4E2 | <b>TX Driving Strength Control.</b>                                                                                                                                                                                                                                                                                                                         |
| 5      | CLK_SMT    | <b>RX input buffer Schmitt trigger hysteresis control enable. High asserted.</b><br>SMT=1, Schmitt Trigger enable                                                                                                                                                                                                                                           |
| 4      | CLK_PUPD   | <b>Pull-up / pull-down selection.</b><br>0: pull-up resistor<br>1: pull-down resistor<br>CLK pad default no pull                                                                                                                                                                                                                                            |
| 3      | CLK_R1     | <b>Select 50K resistor (0: not select, 1: select)</b>                                                                                                                                                                                                                                                                                                       |
| 2      | CLK_Ro     | <b>Select 10K resistor (0: not select, 1: select)</b>                                                                                                                                                                                                                                                                                                       |
| 1      | CLK_IES    | <b>RX input buffer enable. High asserted.</b><br>Datapath: from IO to O. IES=0, O=0                                                                                                                                                                                                                                                                         |
| 0      | CLK_SR     | <b>Output Slew Rate Control. High asserted.</b><br>SR=1, slower slew.<br>SR=0, no slew rate controlled.                                                                                                                                                                                                                                                     |

**A1040044 FWCMDIOCR T28LP Command Pad Macro IO Control Register** **00000422**

| Bit    | 31 | 30 | 29                 | 28 | 27         | 26 | 25 | 24 | 23 | 22 | 21        | 20       | 19      | 18        | 17       | 16      |  |
|--------|----|----|--------------------|----|------------|----|----|----|----|----|-----------|----------|---------|-----------|----------|---------|--|
| Name   |    |    | CMD_RDSEL          |    |            |    |    |    |    |    |           |          |         | CMD_TDSEL |          |         |  |
| Type   |    |    | RW                 |    |            |    |    |    |    |    |           |          |         | RW        |          |         |  |
| Rese t |    |    | 0                  | 0  | 0          | 0  | 0  | 0  |    |    |           |          | 0       | 0         | 0        | 0       |  |
| Bit    | 15 | 14 | 13                 | 12 | 11         | 10 | 9  | 8  | 7  | 6  | 5         | 4        | 3       | 2         | 1        | 0       |  |
| Name   |    |    | RE_G_CM_D_SA_MP_LE |    | CMD_E8E4E2 |    |    |    |    |    | CM_D_SM_T | CM_D_PUD | CM_D_R1 | CM_D_Ro   | CM_D_IES | CM_D_SR |  |
| Type   |    |    |                    | RW |            | RW |    |    |    |    | RW        | RW       | RW      | RW        | RW       | RW      |  |
| Rese t |    |    |                    | 0  |            | 1  | 0  | 0  |    |    | 1         | 0        | 0       | 0         | 1        | 0       |  |

| Bit(s) | Name      | Description           |
|--------|-----------|-----------------------|
| 29:24  | CMD_RDSEL | <b>RX duty select</b> |

| Bit(s) | Name           | Description                                                                                                                                                                                                                                                                                                                        |
|--------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19:16  | CMD_TDSEL      | RDSEL[1:0]: Input buffer duty high when asserted (high pulse width adjustment)<br>RDSEL[3:2]: Input buffer duty low when asserted (low pulse width adjustment)<br>RDSEL[5:4]: Level shifter duty high when asserted (high pulse width adjustment)<br>RDSEL[7:6]: Level shifter duty low when asserted (low pulse width adjustment) |
| 12     | REG_CMD_SAMPLE | <b>TX duty select</b><br>TDSEL[1:0]: Output level shifter duty high when asserted (high pulse width adjustment)<br>TDSEL[3:2]: Output level shifter duty low when asserted (low pulse width adjustment)                                                                                                                            |
| 10:8   | CMD_E8E4E2     | <b>Select clock edge to latch input bus signal.</b><br>0: Use positive SD clock edge to latch input command<br>1: Use negative SD clock edge to latch input command                                                                                                                                                                |
| 5      | CMD_SMT        | <b>TX Driving Strength Control.</b><br><b>RX input buffer Schmitt trigger hysteresis control enable. High asserted.</b>                                                                                                                                                                                                            |
| 4      | CMD_PUPD       | <b>SMT=1, Schmitt Trigger enable</b><br><b>Pull-up / pull-down selection.</b><br>0: pull-up resistor<br>1: pull-down resistor<br>CMD pad default no pull                                                                                                                                                                           |
| 3      | CMD_R1         | <b>Select 50K resistor (0: not select, 1: select)</b>                                                                                                                                                                                                                                                                              |
| 2      | CMD_R0         | <b>Select 10K resistor (0: not select, 1: select)</b>                                                                                                                                                                                                                                                                              |
| 1      | CMD_IES        | <b>RX input buffer enable. High asserted.</b><br>Datapath: from IO to O. IES=0, O=0                                                                                                                                                                                                                                                |
| 0      | CMD_SR         | <b>Output Slew Rate Control. High asserted.</b><br>SR=1, slower slew.<br>SR=0, no slew rate controlled.                                                                                                                                                                                                                            |

A1040048 FWDataToIOCR\_T28LP Data o Pad Macro IO Control Register 00000422

| Bit           | 31 | 30 | 29                    | 28 | 27                  | 26 | 25 | 24 | 23 | 22 | 21           | 20            | 19                 | 18         | 17           | 16         |
|---------------|----|----|-----------------------|----|---------------------|----|----|----|----|----|--------------|---------------|--------------------|------------|--------------|------------|
| <b>Name</b>   |    |    | <b>DATAo_RDSEL</b>    |    |                     |    |    |    |    |    |              |               | <b>DATAo_TDSEL</b> |            |              |            |
| <b>Type</b>   |    |    | RW                    |    |                     |    |    |    |    |    |              |               | RW                 |            |              |            |
| <b>Rese t</b> |    |    | 0                     | 0  | 0                   | 0  | 0  | 0  |    |    |              |               | 0                  | 0          | 0            | 0          |
| <b>Bit</b>    | 15 | 14 | 13                    | 12 | 11                  | 10 | 9  | 8  | 7  | 6  | 5            | 4             | 3                  | 2          | 1            | 0          |
| <b>Name</b>   |    |    | RE_G_DA_TA_o_SA_MP LE |    | <b>DATAo_E8E4E2</b> |    |    |    |    |    | DA_TA_o_SM_T | DA_TA_o_PU_PD | DA_TA_o_R1         | DA_TA_o_RO | DA_TA_o_I_ES | DA_TA_o_SR |
| <b>Type</b>   |    |    | RW                    |    | RW                  |    |    |    |    |    | RW           | RW            | RW                 | RW         | RW           | RW         |
| <b>Rese t</b> |    |    | 0                     |    | 1                   | 0  | 0  |    |    |    | 1            | 0             | 0                  | 0          | 1            | 0          |

| Bit(s) | Name        | Description                                                                                                                                                                                                                                                                |
|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29:24  | DATAo_RDSEL | <b>RX duty select</b><br>RDSEL[1:0]: Input buffer duty high when asserted (high pulse width adjustment)<br>RDSEL[3:2]: Input buffer duty low when asserted (low pulse width adjustment)<br>RDSEL[5:4]: Level shifter duty high when asserted (high pulse width adjustment) |

| Bit(s) | Name             | Description                                                                                                                                                                                                                                                                              |
|--------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19:16  | DATAo_TDSEL      | RDSEL[7:6]: Level shifter duty low when asserted (low pulse width adjustment)<br><b>TX duty select</b><br>TDSEL[1:0]: Output level shifter duty high when asserted (high pulse width adjustment)<br>TDSEL[3:2]: Output level shifter duty low when asserted (low pulse width adjustment) |
| 12     | REG_DATAo_SAMPLE | <b>Select clock edge to latch input bus signal.</b><br>0: Use positive SD clock edge to latch input data<br>1: Use negative SD clock edge to latch input data                                                                                                                            |
| 10:8   | DATAo_E8E4E2     | <b>RX input buffer Schmitt trigger hysteresis control enable. High asserted.</b>                                                                                                                                                                                                         |
| 5      | DATAo_SMT        | SMT=1, Schmitt Trigger enable                                                                                                                                                                                                                                                            |
| 4      | DATAo_PUPD       | <b>Pull-up / pull-down selection.</b><br>0: pull-up resistor<br>1: pull-down resistor<br>DATA o pad default no pull                                                                                                                                                                      |
| 3      | DATAo_R1         | <b>Select 50K resistor (0: not select, 1: select)</b>                                                                                                                                                                                                                                    |
| 2      | DATAo_R0         | <b>Select 10K resistor (0: not select, 1: select)</b>                                                                                                                                                                                                                                    |
| 1      | DATAo_IES        | <b>RX input buffer enable. High asserted.</b><br>Datapath: from IO to O. IES=0, O=0                                                                                                                                                                                                      |
| 0      | DATAo_SR         | <b>Output Slew Rate Control. High asserted.</b><br>SR=1, slower slew.<br>SR=0, no slew rate controlled.                                                                                                                                                                                  |

| A104004C FWDAT1IOCR T28LP Data 1 Pad Macro IO Control Register 00000422 |                 |    |                       |    |              |    |    |    |             |    |             |               |            |            |             |            |
|-------------------------------------------------------------------------|-----------------|----|-----------------------|----|--------------|----|----|----|-------------|----|-------------|---------------|------------|------------|-------------|------------|
| Bit                                                                     | 31              | 30 | 29                    | 28 | 27           | 26 | 25 | 24 | 23          | 22 | 21          | 20            | 19         | 18         | 17          | 16         |
| Name                                                                    | DATA1_RDSEL     |    |                       |    |              |    |    |    | DATA1_TDSEL |    |             |               |            |            |             |            |
| Type                                                                    | RW              |    |                       |    |              |    |    |    | RW          |    |             |               |            |            |             |            |
| Reset                                                                   | 0 0 0 0 0 0 0 0 |    |                       |    |              |    |    |    | 0 0 0 0     |    |             |               |            |            |             |            |
| Bit                                                                     | 15              | 14 | 13                    | 12 | 11           | 10 | 9  | 8  | 7           | 6  | 5           | 4             | 3          | 2          | 1           | 0          |
| Name                                                                    |                 |    | RE_G_DA_TA1_S_AM_PL_E |    | DATA1_E8E4E2 |    |    |    |             |    | DA_TA1_S_MT | DA_TA1_P_UP_D | DA_TA1_R_1 | DA_TA1_R_0 | DA_TA1_IE_S | DA_TA1_S_R |
| Type                                                                    |                 |    | RW                    |    | RW           |    |    |    |             |    | RW          | RW            | RW         | RW         | RW          | RW         |
| Reset                                                                   |                 |    | 0                     |    | 1 0 0        |    |    |    |             |    | 1           | 0             | 0          | 0          | 1           | 0          |

| Bit(s) | Name        | Description                                                                                                                                                                                                                                                                                                                                                 |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29:24  | DATA1_RDSEL | <b>RX duty select</b><br>RDSEL[1:0]: Input buffer duty high when asserted (high pulse width adjustment)<br>RDSEL[3:2]: Input buffer duty low when asserted (low pulse width adjustment)<br>RDSEL[5:4]: Level shifter duty high when asserted (high pulse width adjustment)<br>RDSEL[7:6]: Level shifter duty low when asserted (low pulse width adjustment) |
| 19:16  | DATA1_TDSEL | <b>TX duty select</b><br>TDSEL[1:0]: Output level shifter duty high when asserted (high pulse width adjustment)<br>TDSEL[3:2]: Output level shifter duty low when asserted (low pulse width adjustment)                                                                                                                                                     |

| Bit(s) | Name             | Description                                                                                                                                                                            |
|--------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12     | REG_DATA1_SAMPLE | width adjustment)<br><b>Select clock edge to latch input bus signal.</b><br>0: Use positive SD clock edge to latch input data 1<br>1: Use negative SD clock edge to latch input data 1 |
| 10:8   | DATA1_E8E4E2     | <b>TX Driving Strength Control.</b>                                                                                                                                                    |
| 5      | DATA1_SMT        | <b>RX input buffer Schmitt trigger hysteresis control enable. High asserted.</b>                                                                                                       |
| 4      | DATA1_PUPD       | SMT=1, Schmitt Trigger enable<br><b>Pull-up / pull-down selection.</b><br>0: pull-up resistor<br>1: pull-down resistor<br>DATA 1 pad default no pull                                   |
| 3      | DATA1_R1         | <b>Select 50K resistor (0: not select, 1: select)</b>                                                                                                                                  |
| 2      | DATA1_RO         | <b>Select 10K resistor (0: not select, 1: select)</b>                                                                                                                                  |
| 1      | DATA1_IES        | <b>RX input buffer enable. High asserted.</b><br>Datapath: from IO to O. IES=0, O=0                                                                                                    |
| 0      | DATA1_SR         | <b>Output Slew Rate Control. High asserted.</b><br>SR=1, slower slew.<br>SR=0, no slew rate controlled.                                                                                |

| A1040050 FWDAT2IOCR T28LP Data 2 Pad Macro IO Control Register 00000422 |    |    |             |    |    |    |    |    |    |    |              |    |                |                |                |                |
|-------------------------------------------------------------------------|----|----|-------------|----|----|----|----|----|----|----|--------------|----|----------------|----------------|----------------|----------------|
| Bit                                                                     | 31 | 30 | 29          | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21           | 20 | 19             | 18             | 17             | 16             |
| Name                                                                    |    |    | DATA2_RDSEL |    |    |    |    |    |    |    |              |    | DATA2_TDSEL    |                |                |                |
| Type                                                                    |    |    | RW          |    |    |    |    |    |    |    |              |    | RW             |                |                |                |
| Reset                                                                   |    |    | 0           | 0  | 0  | 0  | 0  | 0  |    |    |              |    | 0              | 0              | 0              | 0              |
| Bit                                                                     | 15 | 14 | 13          | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5            | 4  | 3              | 2              | 1              | 0              |
| Name                                                                    |    |    | RE<br>G_    | DA | TA | 2_ | SA | MP | LE |    | DATA2_E8E4E2 |    | DA<br>TA<br>2_ | DA<br>TA<br>2_ | DA<br>TA<br>2_ | DA<br>TA<br>2_ |
| Type                                                                    |    |    | RW          |    | RW |    |    |    |    | RW | RW           | RW | RW             | RW             | RW             |                |
| Reset                                                                   |    |    | 0           |    | 1  | 0  | 0  |    |    | 1  | 0            | 0  | 0              | 1              | 0              |                |

| Bit(s) | Name             | Description                                                                                                                                                                                                                                                                                                                                                 |
|--------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29:24  | DATA2_RDSEL      | <b>RX duty select</b><br>RDSEL[1:0]: Input buffer duty high when asserted (high pulse width adjustment)<br>RDSEL[3:2]: Input buffer duty low when asserted (low pulse width adjustment)<br>RDSEL[5:4]: Level shifter duty high when asserted (high pulse width adjustment)<br>RDSEL[7:6]: Level shifter duty low when asserted (low pulse width adjustment) |
| 19:16  | DATA2_TDSEL      | <b>TX duty select</b><br>TDSEL[1:0]: Output level shifter duty high when asserted (high pulse width adjustment)<br>TDSEL[3:2]: Output level shifter duty low when asserted (low pulse width adjustment)                                                                                                                                                     |
| 12     | REG_DATA2_SAMPLE | <b>Select clock edge to latch input bus signal.</b><br>0: Use positive SD clock edge to latch input data 2<br>1: Use negative SD clock edge to latch input data 2                                                                                                                                                                                           |
| 10:8   | DATA2_E8E4E2     | <b>TX Driving Strength Control.</b>                                                                                                                                                                                                                                                                                                                         |
| 5      | DATA2_SMT        | <b>RX input buffer Schmitt trigger hysteresis control enable.</b>                                                                                                                                                                                                                                                                                           |

| Bit(s) | Name       | Description                                                                                                                                                                   |
|--------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4      | DATA2_PUPD | <b>High asserted.</b><br>SMT=1, Schmitt Trigger enable<br><b>Pull-up / pull-down selection.</b><br>0: pull-up resistor<br>1: pull-down resistor<br>DATA 2 pad default no pull |
| 3      | DATA2_R1   | <b>Select 50K resistor (0: not select, 1: select)</b>                                                                                                                         |
| 2      | DATA2_R0   | <b>Select 10K resistor (0: not select, 1: select)</b>                                                                                                                         |
| 1      | DATA2_IES  | <b>RX input buffer enable. High asserted.</b><br>Datapath: from IO to O. IES=0, O=0                                                                                           |
| 0      | DATA2_SR   | <b>Output Slew Rate Control. High asserted.</b><br>SR=1, slower slew.<br>SR=0, no slew rate controlled.                                                                       |

**A1040054 FWDAT3IOCR T28LP Data 3 Pad Macro IO Control Register 0000042A**

| Bit    | 31 | 30 | 29          | 28       | 27 | 26           | 25 | 24 | 23             | 22             | 21             | 20             | 19             | 18             | 17             | 16             |   |
|--------|----|----|-------------|----------|----|--------------|----|----|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|---|
| Name   |    |    | DATA3_RDSEL |          |    |              |    |    |                |                |                |                |                | DATA3_TDSEL    |                |                |   |
| Type   |    |    | RW          |          |    |              |    |    |                |                |                |                |                | RW             |                |                |   |
| Rese t |    |    | 0           | 0        | 0  | 0            | 0  | 0  |                |                |                |                |                | 0              | 0              | 0              | 0 |
| Bit    | 15 | 14 | 13          | 12       | 11 | 10           | 9  | 8  | 7              | 6              | 5              | 4              | 3              | 2              | 1              | 0              |   |
| Name   |    |    | RE<br>G_    | DA<br>TA | 3_ | DATA3_E8E4E2 |    |    | DA<br>TA<br>3_ |   |
| Type   |    |    |             | RW       |    | RW           |    |    | RW             |   |
| Rese t |    |    | 0           |          | 1  | 0            | 0  |    | 1              | 0              | 1              | 0              | 1              | 0              | 1              | 0              |   |

| Bit(s) | Name             | Description                                                                                                                                                                                                                                                                                                                                                 |
|--------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29:24  | DATA3_RDSEL      | <b>RX duty select</b><br>RDSEL[1:0]: Input buffer duty high when asserted (high pulse width adjustment)<br>RDSEL[3:2]: Input buffer duty low when asserted (low pulse width adjustment)<br>RDSEL[5:4]: Level shifter duty high when asserted (high pulse width adjustment)<br>RDSEL[7:6]: Level shifter duty low when asserted (low pulse width adjustment) |
| 19:16  | DATA3_TDSEL      | <b>TX duty select</b><br>TDSEL[1:0]: Output level shifter duty high when asserted (high pulse width adjustment)<br>TDSEL[3:2]: Output level shifter duty low when asserted (low pulse width adjustment)                                                                                                                                                     |
| 12     | REG_DATA3_SAMPLE | <b>Select clock edge to latch input bus signal.</b><br>0: Use positive SD clock edge to latch input data 3<br>1: Use negative SD clock edge to latch input data 3                                                                                                                                                                                           |
| 10:8   | DATA3_E8E4E2     | <b>TX Driving Strength Control.</b>                                                                                                                                                                                                                                                                                                                         |
| 5      | DATA3_SMT        | <b>RX input buffer Schmitt trigger hysteresis control enable. High asserted.</b><br>SMT=1, Schmitt Trigger enable                                                                                                                                                                                                                                           |
| 4      | DATA3_PUPD       | <b>Pull-up / pull-down selection.</b><br>0: pull-up resistor<br>1: pull-down resistor<br>DATA 3 pad default would pull up with 50K resistor. (for card                                                                                                                                                                                                      |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                                                                      |
|---------------|-------------|---------------------------------------------------------------------------------------------------------|
|               |             | detection)<br>After host driver writes cd_disable to CCCR register, data 3 pad would become no pull.    |
| 3             | DATA3_R1    | <b>Select 50K resistor (0: not select, 1: select)</b>                                                   |
| 2             | DATA3_RO    | <b>Select 10K resistor (0: not select, 1: select)</b>                                                   |
| 1             | DATA3IES    | <b>RX input buffer enable. High asserted.</b><br>Datapath: from IO to O. IES=0, O=0                     |
| 0             | DATA3_SR    | <b>Output Slew Rate Control. High asserted.</b><br>SR=1, slower slew.<br>SR=0, no slew rate controlled. |

**A1040058 FWCLKDLYCR**

## Clock Pad Macro Delay Chain Control Register

oooooooo

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23            | 22 | 21 | 20 | 19 | 18 | 17 | 16          |
|-------|----|----|----|----|----|----|----|----|---------------|----|----|----|----|----|----|-------------|
| Name  |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |             |
| Type  |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |             |
| Reset |    |    |    |    |    |    |    |    |               |    |    |    |    |    |    |             |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7             | 6  | 5  | 4  | 3  | 2  | 1  | 0           |
| Name  |    |    |    |    |    |    |    |    | REG_CK_DLY_EN |    |    |    |    |    |    | CLK_DLY_SEL |
| Type  |    |    |    |    |    |    |    |    | RW            |    |    |    |    |    |    | RW          |
| Reset |    |    |    |    |    |    |    |    | 0             |    |    |    | 0  | 0  | 0  | 0           |

| <b>Bit(s)</b> | <b>Name</b>   | <b>Description</b>                                                                                                                                                                    |
|---------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7             | REG_CK_DLY_EN | <b>Enable input clock through delay chain.</b><br>0: Input clock does not pass through delay chain.<br>1: Input clock pass through delay chain.<br><b>CLK Pad Input Delay Control</b> |
| 4:0           | CLK_DLY_SEL   | This register is used to add delay to CLK phase.<br>Total 32 stages                                                                                                                   |

**A104005C FWCMDLRYCR**

# **Command Pad Macro Delay Chain Control Register**

**oooooooo**

| Bit   | 31      | 30 | 29 | 28            | 27 | 26 | 25 | 24 | 23                                       | 22                                            | 21 | 20 | 19            | 18 | 17 | 16 |   |
|-------|---------|----|----|---------------|----|----|----|----|------------------------------------------|-----------------------------------------------|----|----|---------------|----|----|----|---|
| Name  |         |    |    |               |    |    |    |    | RE<br>G<br>CM<br>D<br>O<br>DL<br>Y<br>EN | RE<br>G<br>CM<br>D<br>OE<br>D<br>LY<br>E<br>N |    |    | CMD_O_DLY     |    |    |    |   |
| Type  |         |    |    |               |    |    |    |    | RW                                       | RW                                            |    |    | RW            |    |    |    |   |
| Reset |         |    |    |               |    |    |    |    | 0                                        | 0                                             |    |    | 0             | 0  | 0  | 0  | 0 |
| Bit   | 15      | 14 | 13 | 12            | 11 | 10 | 9  | 8  | 7                                        | 6                                             | 5  | 4  | 3             | 2  | 1  | 0  |   |
| Name  | RE<br>G |    |    | CMD_NEG_I_DLY |    |    |    |    | RE<br>G                                  |                                               |    |    | CMD_POS_I_DLY |    |    |    |   |

|        |                                           |  |  |   |    |   |   |   |                                           |  |   |    |   |   |   |
|--------|-------------------------------------------|--|--|---|----|---|---|---|-------------------------------------------|--|---|----|---|---|---|
|        | CM<br>D<br>NE<br>G_I<br>D<br>LY<br>E<br>N |  |  |   |    |   |   |   | CM<br>D<br>PO<br>S_I<br>D<br>LY<br>E<br>N |  |   |    |   |   |   |
| Type   | RW                                        |  |  |   | RW |   |   |   | RW                                        |  |   | RW |   |   |   |
| Rese t | 0                                         |  |  | 0 | 0  | 0 | 0 | 0 |                                           |  | 0 | 0  | 0 | 0 | 0 |

| Bit(s) | Name                 | Description                                                                                                                                                                                        |
|--------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23     | REG_CMD_O_DLY_EN     | <b>Enable output response through delay chain. (to I of IOCUP)</b><br>0: Output response does not pass through delay chain.<br>1: Output response passes through delay chain.                      |
| 22     | REG_CMD_OE_DLY_EN    | <b>Enable response output enable through delay chain. (to E of IOCUP)</b><br>0: Response output enable does not pass through delay chain.<br>1: Response output enable passes through delay chain. |
| 20:16  | CMD_O_DLY            | <b>CMD Pad Output Delay Control</b><br>This register is used to add delay to an output response phase.<br>Total 32 stages                                                                          |
| 15     | REG_CMD_NEG_I_DLY_EN | <b>Enable input command through delay chain to be latched with negative clock edge.</b><br>0: Input command does not pass through delay chain.<br>1: Input command passes through delay chain.     |
| 12:8   | CMD_NEG_I_DLY        | <b>CMD Pad Input Delay Control for data latch with negative clock edge.</b><br>This register is used to add delay to input command phase.<br>Total 32 stages                                       |
| 7      | REG_CMD_POS_I_DLY_EN | <b>Enable input command through delay chain to be latched with positive clock edge.</b><br>0: Input command does not pass through delay chain.<br>1: Input command passes through delay chain.     |
| 4:0    | CMD_POS_I_DLY        | <b>CMD Pad Input Delay Control for data latch with positive clock edge.</b><br>This register is used to add delay to an input command phase.<br>Total 32 stages                                    |

**A1040060 FWODATDLYCR SDIO Output Data Delay Chain Control 00000000 Register**

|        |                                                |                                                |    |    |    |    |    |    |                                                |                                                |    |    |    |    |    |    |
|--------|------------------------------------------------|------------------------------------------------|----|----|----|----|----|----|------------------------------------------------|------------------------------------------------|----|----|----|----|----|----|
| Bit    | 31                                             | 30                                             | 29 | 28 | 27 | 26 | 25 | 24 | 23                                             | 22                                             | 21 | 20 | 19 | 18 | 17 | 16 |
| Name   | RE<br>G_ DA<br>T3<br>_O<br>_D<br>LY<br>_E<br>N | RE<br>G_ DA<br>T3<br>_O<br>_D<br>LY<br>_E<br>N |    |    |    |    |    |    | RE<br>G_ DA<br>T2<br>_O<br>_D<br>LY<br>_E<br>N | RE<br>G_ DA<br>T2<br>_O<br>_D<br>LY<br>_E<br>N |    |    |    |    |    |    |
| Type   | RW                                             | RW                                             |    | RW |    |    |    |    | RW                                             | RW                                             |    | RW |    |    |    |    |
| Rese t | 0                                              | 0                                              |    | 0  | 0  | 0  | 0  | 0  | 0                                              | 0                                              |    | 0  | 0  | 0  | 0  | 0  |
| Bit    | 15                                             | 14                                             | 13 | 12 | 11 | 10 | 9  | 8  | 7                                              | 6                                              | 5  | 4  | 3  | 2  | 1  | 0  |
| Name   | RE<br>G_ DA<br>T1<br>_O<br>OE                  | RE<br>G_ DA<br>T1<br>_O<br>OE                  |    |    |    |    |    |    | RE<br>G_ DA<br>To<br>_O                        | RE<br>G_ DA<br>To<br>_O                        |    |    |    |    |    |    |
|        |                                                |                                                |    |    |    |    |    |    |                                                |                                                |    |    |    |    |    |    |
|        |                                                |                                                |    |    |    |    |    |    |                                                |                                                |    |    |    |    |    |    |

|                   | <b>DL<br/>Y_</b><br><b>EN</b> | <b>D<br/>LY</b><br><b>_E</b><br><b>N</b> |  |    |   |   |   |   |   | <b>D<br/>LY</b><br><b>_E</b><br><b>N</b> | <b>E<br/>DL<br/>Y_</b><br><b>EN</b> |  |    |   |   |   |   |  |
|-------------------|-------------------------------|------------------------------------------|--|----|---|---|---|---|---|------------------------------------------|-------------------------------------|--|----|---|---|---|---|--|
| <b>Type</b>       | RW                            | RW                                       |  | RW |   |   |   |   |   | RW                                       | RW                                  |  | RW |   |   |   |   |  |
| <b>Rese<br/>t</b> | o                             | o                                        |  | o  | o | o | o | o | o | o                                        | o                                   |  | o  | o | o | o | o |  |

| <b>Bit(s)</b> | <b>Name</b>        | <b>Description</b>                                                                                                                                                                           |
|---------------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31            | REG_DAT3_O_DLY_EN  | <b>Enable output data 3 through delay chain. (to I of IOCUP)</b><br>0: Output data 3 does not pass through delay chain.<br>1: Output data 3 passes through delay chain.                      |
| 30            | REG_DAT3_OE_DLY_EN | <b>Enable data 3 output enable through delay chain. (to E of IOCUP)</b><br>0: Data 3 output enable does not pass through delay chain.<br>1: Data 3 output enable passes through delay chain. |
| 28:24         | DAT3_O_DLY         | <b>DATA 3 Pad Output Delay Control</b><br>This register is used to add delay to output response phase.<br>Total 32 stages                                                                    |
| 23            | REG_DAT2_O_DLY_EN  | <b>Enable output data 2 through delay chain. (to I of IOCUP)</b><br>0: Output data 2 does not pass through delay chain.<br>1: Output data 2 passes through delay chain.                      |
| 22            | REG_DAT2_OE_DLY_EN | <b>Enable data 2 output enable through delay chain. (to E of IOCUP)</b><br>0: Data 2 output enable does not pass through delay chain.<br>1: Data 2 output enable pass through delay chain.   |
| 20:16         | DAT2_O_DLY         | <b>DATA 2 Pad Output Delay Control</b><br>This register is used to add delay to output response phase.<br>Total 32 stages                                                                    |
| 15            | REG_DAT1_O_DLY_EN  | <b>Enable output data 1 through delay chain. (to I of IOCUP)</b><br>0: Output data 1 does not pass through delay chain.<br>1: Output data 1 passes through delay chain.                      |
| 14            | REG_DAT1_OE_DLY_EN | <b>Enable data 1 output enable through delay chain. (to E of IOCUP)</b><br>0: Data 1 output enable does not pass through delay chain.<br>1: Data 1 output enable passes through delay chain. |
| 12:8          | DAT1_O_DLY         | <b>DATA 1 Pad Output Delay Control</b><br>This register is used to add delay to output response phase.<br>Total 32 stages                                                                    |
| 7             | REG_DAT0_O_DLY_EN  | <b>Enable output data 0 through delay chain. (to I of IOCUP)</b><br>0: Output data 0 does not pass through delay chain.<br>1: Output data 0 passes through delay chain.                      |
| 6             | REG_DAT0_OE_DLY_EN | <b>Enable data 0 output enable through delay chain. (to E of IOCUP)</b><br>0: Data 0 output enable does not pass through delay chain.<br>1: Data 0 output enable passes through delay chain. |
| 4:0           | DAT0_O_DLY         | <b>DATA 0 Pad Output Delay Control</b><br>This register is used to add delay to output response phase.<br>Total 32 stages                                                                    |

| <b>A1040064 FWIDATDLYCR1</b> |                                                     |    |    |                       |    |    |    |    |    | <b>SDIO Input Data Delay Chain Control Register 1</b> |    |    |                       |    |    |    |  |  |
|------------------------------|-----------------------------------------------------|----|----|-----------------------|----|----|----|----|----|-------------------------------------------------------|----|----|-----------------------|----|----|----|--|--|
| <b>Bit</b>                   | 31                                                  | 30 | 29 | 28                    | 27 | 26 | 25 | 24 | 23 | 22                                                    | 21 | 20 | 19                    | 18 | 17 | 16 |  |  |
| <b>Name</b>                  | RE<br>G_<br>DA<br>T3<br>_P<br>OS<br>_I_<br>DL<br>Y_ |    |    | <b>DAT3_POS_I_DLY</b> |    |    |    |    |    | RE<br>G_<br>DA<br>T2<br>_P<br>OS<br>_I_<br>DL<br>Y_   |    |    | <b>DAT2_POS_I_DLY</b> |    |    |    |  |  |

| Type   | EN                                          |    |    | RW             |    |    |   |   |   | EN                                         |   |   | RW             |   |   |   |  |  |
|--------|---------------------------------------------|----|----|----------------|----|----|---|---|---|--------------------------------------------|---|---|----------------|---|---|---|--|--|
| Rese t | RW                                          | o  |    | o              | o  | o  | o | o | o | o                                          |   | o | o              | o | o | o |  |  |
| Bit    | 15                                          | 14 | 13 | 12             | 11 | 10 | 9 | 8 | 7 | 6                                          | 5 | 4 | 3              | 2 | 1 | 0 |  |  |
| Name   | RE<br>G_ DA<br>T1_ PO<br>S_I D<br>LY E<br>N |    |    | DAT1_POS_I_DLY |    |    |   |   |   | RE<br>G_ DA<br>To<br>P OS<br>I_ DL<br>Y EN |   |   | DAT0_POS_I_DLY |   |   |   |  |  |
| Type   | RW                                          |    |    | RW             |    |    |   |   |   | RW                                         |   |   | RW             |   |   |   |  |  |
| Rese t | o                                           |    |    | o              | o  | o  | o | o | o |                                            |   | o | o              | o | o | o |  |  |

| Bit(s) | Name                  | Description                                                                                                                                                                                                                                                                                                                                                   |
|--------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31     | REG_DAT3_POS_I_DLY_EN | <b>Enable input data 3 through delay chain to be latched with positive clock edge.</b><br>0: Input data 3 does not pass through delay chain.<br>1: Input data 3 passes through delay chain.<br><b>DATA 3 Pad Input Delay Control for datalatch with positive clock edge.</b><br>This register is used to add delay to input data 3 phase.<br>Total 32 stages  |
| 28:24  | DAT3_POS_I_DLY        | <b>DATA 3 Pad Input Delay Control for datalatch with positive clock edge.</b><br>This register is used to add delay to input data 3 phase.<br>Total 32 stages                                                                                                                                                                                                 |
| 23     | REG_DAT2_POS_I_DLY_EN | <b>Enable input data 2 through delay chain to be latched with positive clock edge.</b><br>0: Input data 2 does not pass through delay chain.<br>1: Input data 2 passes through delay chain.<br><b>DATA 2 Pad Input Delay Control for data latch with positive clock edge.</b><br>This register is used to add delay to input data 2 phase.<br>Total 32 stages |
| 20:16  | DAT2_POS_I_DLY        | <b>DATA 2 Pad Input Delay Control for data latch with positive clock edge.</b><br>This register is used to add delay to input data 2 phase.<br>Total 32 stages                                                                                                                                                                                                |
| 15     | REG_DAT1_POS_I_DLY_EN | <b>Enable input data 1 through delay chain to be latched with positive clock edge.</b><br>0: Input data 1 does not pass through delay chain.<br>1: Input data 1 passes through delay chain.<br><b>DATA 1 Pad Input Delay Control for data latch with positive clock edge.</b><br>This register is used to add delay to input data 1 phase.<br>Total 32 stages |
| 12:8   | DAT1_POS_I_DLY        | <b>DATA 1 Pad Input Delay Control for data latch with positive clock edge.</b><br>This register is used to add delay to input data 1 phase.<br>Total 32 stages                                                                                                                                                                                                |
| 7      | REG_DATO_POS_I_DLY_EN | <b>Enable input data 0 through delay chain to be latched with positive clock edge.</b><br>0: Input data 0 does not pass through delay chain.<br>1: Input data 0 passes through delay chain.<br><b>DATA 0 Pad Input Delay Control for data latch with positive clock edge.</b><br>This register is used to add delay to input data 0 phase.<br>Total 32 stages |
| 4:0    | DATO_POS_I_DLY        |                                                                                                                                                                                                                                                                                                                                                               |

| A1040068 FWIDATDLYCR2 |                            |    |    |                |    |    |    | SDIO Input Data Delay Chain Control Register 2 |    |                            |    |    |                |    |    | oooooooooooo |  |  |  |  |  |  |  |
|-----------------------|----------------------------|----|----|----------------|----|----|----|------------------------------------------------|----|----------------------------|----|----|----------------|----|----|--------------|--|--|--|--|--|--|--|
| Bit                   | 31                         | 30 | 29 | 28             | 27 | 26 | 25 | 24                                             | 23 | 22                         | 21 | 20 | 19             | 18 | 17 | 16           |  |  |  |  |  |  |  |
| Name                  | RE<br>G_ DA<br>T3_ N<br>EG |    |    | DAT3_NEG_I_DLY |    |    |    |                                                |    | RE<br>G_ DA<br>T2_ N<br>EG |    |    | DAT2_NEG_I_DLY |    |    |              |  |  |  |  |  |  |  |
|                       |                            |    |    |                |    |    |    |                                                |    |                            |    |    |                |    |    |              |  |  |  |  |  |  |  |

|       | I<br>DL                                                 |    |    |                |    |    |   |   |   | I<br>DL                                               |   |   |                |   |   |   |   |   |
|-------|---------------------------------------------------------|----|----|----------------|----|----|---|---|---|-------------------------------------------------------|---|---|----------------|---|---|---|---|---|
| Type  | RW                                                      |    |    | RW             |    |    |   |   |   | RW                                                    |   |   | RW             |   |   |   |   |   |
| Reset | 0                                                       |    |    | 0              | 0  | 0  | 0 | 0 | 0 | 0                                                     |   |   | 0              | 0 | 0 | 0 | 0 | 0 |
| Bit   | 15                                                      | 14 | 13 | 12             | 11 | 10 | 9 | 8 | 7 | 6                                                     | 5 | 4 | 3              | 2 | 1 | 0 |   |   |
| Name  | RE<br>G_<br>DA<br>T1_<br>NE<br>G_I<br>D<br>LY<br>E<br>N |    |    | DAT1_NEG_I_DLY |    |    |   |   |   | RE<br>G_<br>DA<br>To<br>N<br>EG<br>I<br>DL<br>Y<br>EN |   |   | DATo_NEG_I_DLY |   |   |   |   |   |
| Type  | RW                                                      |    |    | RW             |    |    |   |   |   | RW                                                    |   |   | RW             |   |   |   |   |   |
| Reset | 0                                                       |    |    | 0              | 0  | 0  | 0 | 0 | 0 |                                                       |   |   | 0              | 0 | 0 | 0 | 0 | 0 |

| Bit(s) | Name                  | Description                                                                                                                                                                                                                                                                                                                                                   |
|--------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31     | REG_DAT3_NEG_I_DLY_EN | <b>Enable input data 3 through delay chain to be latched with negative clock edge.</b><br>0: Input data 3 does not pass through delay chain.<br>1: Input data 3 passes through delay chain.<br><b>DATA 3 Pad Input Delay Control for data latch with negative clock edge.</b><br>This register is used to add delay to input data 3 phase.<br>Total 32 stages |
| 28:24  | DAT3_NEG_I_DLY        | <b>DATA 3 Pad Input Delay Control for data latch with negative clock edge.</b><br>This register is used to add delay to input data 3 phase.<br>Total 32 stages                                                                                                                                                                                                |
| 23     | REG_DAT2_NEG_I_DLY_EN | <b>Enable input data 2 through delay chain to be latched with negative clock edge.</b><br>0: Input data 2 does not pass through delay chain.<br>1: Input data 2 passes through delay chain.<br><b>DATA 2 Pad Input Delay Control for data latch with negative clock edge.</b><br>This register is used to add delay to input data 2 phase.<br>Total 32 stages |
| 20:16  | DAT2_NEG_I_DLY        | <b>DATA 2 Pad Input Delay Control for data latch with negative clock edge.</b><br>This register is used to add delay to input data 2 phase.<br>Total 32 stages                                                                                                                                                                                                |
| 15     | REG_DAT1_NEG_I_DLY_EN | <b>Enable input data 1 through delay chain to be latched with negative clock edge.</b><br>0: Input data 1 does not pass through delay chain.<br>1: Input data 1 passes through delay chain.<br><b>DATA 1 Pad Input Delay Control for data latch with negative clock edge.</b><br>This register is used to add delay to input data 1 phase.<br>Total 32 stages |
| 12:8   | DAT1_NEG_I_DLY        | <b>DATA 1 Pad Input Delay Control for data latch with negative clock edge.</b><br>This register is used to add delay to input data 1 phase.<br>Total 32 stages                                                                                                                                                                                                |
| 7      | REG_DATO_NEG_I_DLY_EN | <b>Enable input data 0 through delay chain to be latched with negative clock edge.</b><br>0: Input data 0 does not pass through delay chain.<br>1: Input data 0 passes through delay chain.<br><b>DATA 0 Pad Input Delay Control for data latch with negative clock edge.</b><br>This register is used to add delay to input data 0 phase.<br>Total 32 stages |
| 4:0    | DATO_NEG_I_DLY        |                                                                                                                                                                                                                                                                                                                                                               |

**A104006C FWILCHCR****SDIO Input Data Latch Time Control Register**

00011111

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |                          |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------------|
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | REG_CM<br>D_LATCH<br>SEL |

| Type   |    |    |                            |    |    |                            |   |   |                            |   |   |                            |   |   | RW |   |  |
|--------|----|----|----------------------------|----|----|----------------------------|---|---|----------------------------|---|---|----------------------------|---|---|----|---|--|
| Rese t |    |    |                            |    |    |                            |   |   |                            |   |   |                            |   |   | 0  | 1 |  |
| Bit    | 15 | 14 | 13                         | 12 | 11 | 10                         | 9 | 8 | 7                          | 6 | 5 | 4                          | 3 | 2 | 1  | 0 |  |
| Name   |    |    | REG_DA<br>T3_LATC<br>H_SEL |    |    | REG_DA<br>T2_LATC<br>H_SEL |   |   | REG_DA<br>T1_LATC<br>H_SEL |   |   | REG_DA<br>To_LAT<br>CH_SEL |   |   |    |   |  |
| Type   |    |    | RW                         |    |    | RW                         |   |   | RW                         |   |   | RW                         |   |   | RW |   |  |
| Rese t |    |    | 0                          | 1  |    | 0                          | 1 |   | 0                          | 1 |   | 0                          | 1 |   | 0  | 1 |  |

| Bit(s) | Name                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17:16  | REG_CMD_LATCH_SEL   | <b>Controls the input command latch timing depending on the SDIO output enable signal to avoid latching device output data as host transfers data in UHS104 mode.</b><br>2'boo: latch input command after 1 cycle of output enable is asserted.<br>2'b01: latch input command after 2 cycles of output enable is asserted<br>2'b10: latch input command after 3 cycles of output enable is asserted<br>2'b11: latch input command after 4 cycles of output enable is asserted |
| 13:12  | REG_DAT3_LATCH_SEL  | <b>Controls the input data 3 latch timing depending on the SDIO output enable signal to avoid latching device output data as host transfers data in UHS104 mode.</b><br>2'boo: latch input data 3 after 1T of output enable asserted<br>2'b01: latch input data 3 after 2T of output enable asserted<br>2'b10: latch input data 3 after 3T of output enable asserted<br>2'b11: latch input data 3 after 4T of output enable asserted                                          |
| 9:8    | REG_DAT2_LATCH_SEL  | <b>Control the input data 2 latch timing depending on SDIO output enable signal to avoid latching device output data as host transferred data in UHS104 mode.</b><br>2'boo: latch input data 2 after 1T of output enable asserted<br>2'b01: latch input data 2 after 2T of output enable asserted<br>2'b10: latch input data 2 after 3T of output enable asserted<br>2'b11: latch input data 2 after 4T of output enable asserted                                             |
| 5:4    | REG_DAT1_LATCH_SEL  | <b>Control the input data 1 latch timing depending on SDIO output enable signal to avoid latching device output data as host transferred data in UHS104 mode.</b><br>2'boo: latch input data 1 after 1T of output enable asserted<br>2'b01: latch input data 1 after 2T of output enable asserted<br>2'b10: latch input data 1 after 3T of output enable asserted<br>2'b11: latch input data 1 after 4T of output enable asserted                                             |
| 1:0    | REG_DATO__LATCH_SEL | <b>Control the input data 0 latch timing depending on SDIO output enable signal to avoid latching device output data as host transferred data in UHS104 mode.</b><br>2'boo: latch input data 0 after 1T of output enable asserted<br>2'b01: latch input data 0 after 2T of output enable asserted<br>2'b10: latch input data 0 after 3T of output enable asserted<br>2'b11: latch input data 0 after 4T of output enable asserted                                             |

| A1040070 CISoRoo |          | CISo Register 0 |    |    |    |    |    |    |    |    |    |    |    | 00000000 |    |    |  |
|------------------|----------|-----------------|----|----|----|----|----|----|----|----|----|----|----|----------|----|----|--|
| Bit              | 31       | 30              | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18       | 17 | 16 |  |
| Name             | CISo_Woo |                 |    |    |    |    |    |    |    |    |    |    |    |          |    |    |  |
| Type             | RW       |                 |    |    |    |    |    |    |    |    |    |    |    |          |    |    |  |

| Bit(s) | Name     | Description                                        |
|--------|----------|----------------------------------------------------|
| 31:0   | CISO_Woo | CISO Register used in ciscc firmware register mode |

| <b>A1040074 CISoR01</b> |                 | <b>CISO Register 1</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |  | <b>00000000</b> |  |  |  |
|-------------------------|-----------------|------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--|-----------------|--|--|--|
| <b>Bit</b>              | 31              | 30                     | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |  |                 |  |  |  |
| <b>Nam<br/>e</b>        | <b>CISO_W01</b> |                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |  |                 |  |  |  |
| <b>Type</b>             | <b>RW</b>       |                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |  |                 |  |  |  |
| <b>Rese<br/>t</b>       | 0               | 0                      | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |  |                 |  |  |  |
| <b>Bit</b>              | 15              | 14                     | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |  |                 |  |  |  |
| <b>Nam<br/>e</b>        | <b>CISO_W01</b> |                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |  |                 |  |  |  |
| <b>Type</b>             | <b>RW</b>       |                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |  |                 |  |  |  |
| <b>Rese<br/>t</b>       | 0               | 0                      | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |  |                 |  |  |  |

| Bit(s) | Name     | Description                                        |
|--------|----------|----------------------------------------------------|
| 31:0   | CISO_W01 | CISO Register used in ciscc firmware register mode |

| Bit(s) | Name     | Description                                        |
|--------|----------|----------------------------------------------------|
| 31:0   | CISo_Wo2 | CISO Register used in ciscc firmware register mode |

| Bit   | 15       | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | CISO_Wo3 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | RW       |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0        | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| Bit(s) | Name     | Description                              |
|--------|----------|------------------------------------------|
| 31:0   | CISO_Wo3 | CISO Register used in cisc register mode |

| A1040080 CISO_R04 |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CISO Register 4 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 00000000 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Bit               | 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name              | CISO_Wo4 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type              | RW       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reset             | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Bit               | 15       | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name              | CISO_Wo4 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type              | RW       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reset             | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bit(s) | Name     | Description                              |
|--------|----------|------------------------------------------|
| 31:0   | CISO_Wo4 | CISO Register used in cisc register mode |

| A1040084 CISO_R05 |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CISO Register 5 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 00000000 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Bit               | 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name              | CISO_Wo5 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type              | RW       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reset             | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Bit               | 15       | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name              | CISO_Wo5 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type              | RW       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reset             | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bit(s) | Name     | Description                              |
|--------|----------|------------------------------------------|
| 31:0   | CISO_Wo5 | CISO Register used in cisc register mode |

| A1040088 CISO_R06 |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CISO Register 6 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 00000000 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Bit               | 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name              | CISO_Wo6 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type              | RW       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reset             | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Bit               | 15       | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|              |                 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|--------------|-----------------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| <b>Name</b>  | <b>CISO_Wo6</b> |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>  | RW              |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
| <b>Reset</b> | 0               | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                       |
|---------------|-------------|------------------------------------------|
| 31:0          | CISO_Wo6    | CISO Register used in cisc register mode |

**A104008C CISO\_Ro7 CISO Register 7 00000000**

|              |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|--------------|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Bit</b>   | 31              | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b>  | <b>CISO_Wo7</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>   | 15              | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | <b>CISO_Wo7</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                       |
|---------------|-------------|------------------------------------------|
| 31:0          | CISO_Wo7    | CISO Register used in cisc register mode |

**A1040090 CISO\_Ro8 CISO Register 8 00000000**

|              |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|--------------|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Bit</b>   | 31              | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b>  | <b>CISO_Wo8</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>   | 15              | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | <b>CISO_Wo8</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                       |
|---------------|-------------|------------------------------------------|
| 31:0          | CISO_Wo8    | CISO Register used in cisc register mode |

**A1040094 CISO\_Ro9 CISO Register 9 00000000**

|              |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|--------------|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Bit</b>   | 31              | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b>  | <b>CISO_Wo9</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>   | 15              | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | <b>CISO_Wo9</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Type   | RW |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|--------|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Rese t | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| Bit(s) | Name     | Description                                        |
|--------|----------|----------------------------------------------------|
| 31:0   | CISo_Wo9 | CISo Register used in ciscc firmware register mode |

| A1040098 CISoRoA |          | CISo Register A |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   | 00000000 |
|------------------|----------|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----------|
| Bit              | 31       | 30              | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |   |          |
| Name             | CISo_WoA |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |          |
| Type             | RW       |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |          |
| Rese t           | 0        | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 |          |
| Bit              | 15       | 14              | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |   |          |
| Name             | CISo_WoA |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |          |
| Type             | RW       |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |          |
| Rese t           | 0        | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 |          |

| Bit(s) | Name     | Description                                        |
|--------|----------|----------------------------------------------------|
| 31:0   | CISo_WoA | CISo Register used in ciscc firmware register mode |

| A104009C CISoRoB |          | CISo Register B |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   | 00000000 |
|------------------|----------|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----------|
| Bit              | 31       | 30              | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |   |          |
| Name             | CISo_WoB |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |          |
| Type             | RW       |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |          |
| Rese t           | 0        | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 |          |
| Bit              | 15       | 14              | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |   |          |
| Name             | CISo_WoB |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |          |
| Type             | RW       |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |          |
| Rese t           | 0        | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 |          |

| Bit(s) | Name     | Description                                        |
|--------|----------|----------------------------------------------------|
| 31:0   | CISo_WoB | CISo Register used in ciscc firmware register mode |

| A10400Ao CISoRoC |          | CISo Register C |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   | 00000000 |
|------------------|----------|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----------|
| Bit              | 31       | 30              | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |   |          |
| Name             | CISo_WoC |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |          |
| Type             | RW       |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |          |
| Rese t           | 0        | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 |          |
| Bit              | 15       | 14              | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |   |          |
| Name             | CISo_WoC |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |          |
| Type             | RW       |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |          |
| Rese t           | 0        | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 |          |

**t** | | | | | | | | | | | | | | | |

| Bit(s) | Name     | Description                                               |
|--------|----------|-----------------------------------------------------------|
| 31:0   | CISo_WoC | <b>CISO Register used in ciscc firmware register mode</b> |

| Bit(s) | Name     | Description                                               |
|--------|----------|-----------------------------------------------------------|
| 31:0   | CISO_WoD | <b>CISO Register used in ciscc firmware register mode</b> |

| Bit(s) | Name     | Description                                               |
|--------|----------|-----------------------------------------------------------|
| 31:0   | CISO_WoE | <b>CISO Register used in ciscc firmware register mode</b> |

| Bit(s) | Name     | Description                                        |
|--------|----------|----------------------------------------------------|
| 31:0   | CISo_WoF | CISo Register used in ciscc firmware register mode |

| <b>A10400B0 CIS1R00</b> |                 | <b>CIS1 Register 0</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   | <b>oooooooooooo</b> |  |
|-------------------------|-----------------|------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---------------------|--|
| Bit                     | 31              | 30                     | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |   |                     |  |
| Name                    | <b>CIS1_Woo</b> |                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |                     |  |
| Type                    | RW              |                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |                     |  |
| Rese t                  | 0               | 0                      | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0                   |  |
| Bit                     | 15              | 14                     | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |   |                     |  |
| Name                    | <b>CIS1_Woo</b> |                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |                     |  |
| Type                    | RW              |                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |                     |  |
| Rese t                  | 0               | 0                      | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0                   |  |

| Bit(s) | Name     | Description                                        |
|--------|----------|----------------------------------------------------|
| 31:0   | CIS1_Woo | CIS1 Register used in ciscc firmware register mode |

| <b>A10400B4 CIS1R01</b> |                 | <b>CIS1 Register 1</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   | <b>oooooooooooo</b> |  |
|-------------------------|-----------------|------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---------------------|--|
| Bit                     | 31              | 30                     | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |   |                     |  |
| Name                    | <b>CIS1_Wo1</b> |                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |                     |  |
| Type                    | RW              |                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |                     |  |
| Rese t                  | 0               | 0                      | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0                   |  |
| Bit                     | 15              | 14                     | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |   |                     |  |
| Name                    | <b>CIS1_Wo1</b> |                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |                     |  |
| Type                    | RW              |                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |                     |  |
| Rese t                  | 0               | 0                      | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0                   |  |

| Bit(s) | Name     | Description                                        |
|--------|----------|----------------------------------------------------|
| 31:0   | CIS1_Wo1 | CIS1 Register used in ciscc firmware register mode |

| <b>A10400B8 CIS1R02</b> |                 | <b>CIS1 Register 2</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   | <b>oooooooooooo</b> |  |
|-------------------------|-----------------|------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---------------------|--|
| Bit                     | 31              | 30                     | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |   |                     |  |
| Name                    | <b>CIS1_Wo2</b> |                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |                     |  |
| Type                    | RW              |                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |                     |  |
| Rese t                  | 0               | 0                      | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0                   |  |
| Bit                     | 15              | 14                     | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |   |                     |  |
| Name                    | <b>CIS1_Wo2</b> |                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |                     |  |
| Type                    | RW              |                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |                     |  |
| Rese t                  | 0               | 0                      | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0                   |  |

| Bit(s) | Name     | Description                                        |
|--------|----------|----------------------------------------------------|
| 31:0   | CIS1_Wo2 | CIS1 Register used in ciscc firmware register mode |

| Bit(s)                  | Name                                                                                         | Description         |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|----------------------------------------------------------------------------------------------|---------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>A10400BC CIS1Ro3</b> | <b>CIS1 Register 3</b>                                                                       | <b>oooooooooooo</b> |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Bit</b>              | 31    30    29    28    27    26    25    24    23    22    21    20    19    18    17    16 |                     |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Name</b>             | <b>CIS1_Wo3</b>                                                                              |                     |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                           |                     |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Reset</b>            | 0    0    0    0    0    0    0    0    0    0    0    0    0    0    0    0                 |                     |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Bit</b>              | 15    14    13    12    11    10    9    8    7    6    5    4    3    2    1    0           |                     |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Name</b>             | <b>CIS1_Wo3</b>                                                                              |                     |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                           |                     |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Reset</b>            | 0    0    0    0    0    0    0    0    0    0    0    0    0    0    0    0                 |                     |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Bit(s)                  | Name                                                                                         | Description         |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>CIS1_Wo3</b>         | <b>CIS1 Register 3</b>                                                                       | <b>oooooooooooo</b> |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bit(s) | Name | Description |
|--------|------|-------------|
|--------|------|-------------|

**A10400C8 CIS1Ro6 CIS1 Register 6 00000000**

| Bit          | 31              | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  | <b>CIS1_Wo6</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit          | 15              | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | <b>CIS1_Wo6</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name     | Description                                        |
|--------|----------|----------------------------------------------------|
| 31:0   | CIS1_Wo6 | CIS1 Register used in ciscc firmware register mode |

**A10400CC CIS1Ro7 CIS1 Register 7 00000000**

| Bit          | 31              | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  | <b>CIS1_Wo7</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit          | 15              | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | <b>CIS1_Wo7</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name     | Description                                        |
|--------|----------|----------------------------------------------------|
| 31:0   | CIS1_Wo7 | CIS1 Register used in ciscc firmware register mode |

**A10400Do CIS1Ro8 CIS1 Register 8 00000000**

| Bit          | 31              | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  | <b>CIS1_Wo8</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit          | 15              | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | <b>CIS1_Wo8</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name     | Description                                        |
|--------|----------|----------------------------------------------------|
| 31:0   | CIS1_Wo8 | CIS1 Register used in ciscc firmware register mode |

| Bit(s)                  | Name                                            | Description                                        |
|-------------------------|-------------------------------------------------|----------------------------------------------------|
| <b>A10400D4 CIS1R09</b> | <b>CIS1 Register 9</b>                          | <b>oooooooooooo</b>                                |
| <b>Bit</b>              | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |                                                    |
| <b>Name</b>             |                                                 | <b>CIS1_Wo9</b>                                    |
| <b>Type</b>             |                                                 | RW                                                 |
| <b>Reset</b>            | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                 |                                                    |
| <b>Bit</b>              | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0           |                                                    |
| <b>Name</b>             |                                                 | <b>CIS1_Wo9</b>                                    |
| <b>Type</b>             |                                                 | RW                                                 |
| <b>Reset</b>            | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                 |                                                    |
| <b>Bit(s)</b>           | <b>Name</b>                                     | <b>Description</b>                                 |
| 31:0                    | CIS1_Wo9                                        | CIS1 Register used in ciscc firmware register mode |

| A10400D8 CIS1RoA |          | CIS1 Register A |    |    |    |    |    |    |    |    |    |    |    |    |    |    |  | 00000000 |  |  |  |  |  |  |  |
|------------------|----------|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--|----------|--|--|--|--|--|--|--|
| Bit              | 31       | 30              | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |  |          |  |  |  |  |  |  |  |
| Name             | CIS1_WoA |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |  |          |  |  |  |  |  |  |  |
| Type             | RW       |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |  |          |  |  |  |  |  |  |  |
| Reset            | 0        | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |  |          |  |  |  |  |  |  |  |
| Bit              | 15       | 14              | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |  |          |  |  |  |  |  |  |  |
| Name             | CIS1_WoA |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |  |          |  |  |  |  |  |  |  |
| Type             | RW       |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |  |          |  |  |  |  |  |  |  |
| Reset            | 0        | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |  |          |  |  |  |  |  |  |  |

  

| Bit(s) | Name     | Description                                        |
|--------|----------|----------------------------------------------------|
| 31:0   | CIS1_WoA | CIS1 Register used in ciscc firmware register mode |

| A10400DC CIS1RoB |          | CIS1 Register B |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   | 00000000 |
|------------------|----------|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----------|
| Bit              | 31       | 30              | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |   |          |
| Name             | CIS1_WoB |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |          |
| Type             | RW       |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |          |
| Reset            | 0        | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0        |
| Bit              | 15       | 14              | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |   |          |
| Name             | CIS1_WoB |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |          |
| Type             | RW       |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |          |
| Reset            | 0        | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0        |

  

| Bit(s) | Name     | Description                                        |
|--------|----------|----------------------------------------------------|
| 31:0   | CIS1_WoB | CIS1 Register used in ciscc firmware register mode |

| Bit(s)                  | Name            | Description                                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------------------------|-----------------|----------------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>A10400E0 CIS1RoC</b> |                 |                                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Bit</b>              | 31              | 30                                                 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b>             | <b>CIS1_WoC</b> |                                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>             | RW              |                                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>            | 0               | 0                                                  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>              | 15              | 14                                                 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>             | <b>CIS1_WoC</b> |                                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>             | RW              |                                                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>            | 0               | 0                                                  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit(s)                  | Name            | Description                                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| 31:0                    | CIS1_WoC        | CIS1 Register used in ciscc firmware register mode |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| A10400E8 CIS1RoE |          | CIS1 Register E |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   | 00000000 |
|------------------|----------|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|----------|
| Bit              | 31       | 30              | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |   |          |
| Nam e            | CIS1_WoE |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |          |
| Type             | RW       |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |          |
| Rese t           | 0        | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 |          |
| Bit              | 15       | 14              | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |   |          |
| Nam e            | CIS1_WoE |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |          |
| Type             | RW       |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |          |
| Rese t           | 0        | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 |          |

  

| Bit(s) | Name     | Description                                        |
|--------|----------|----------------------------------------------------|
| 31:0   | CIS1_WoE | CIS1 Register used in ciscc firmware register mode |

| Bit(s)                  | Name                                                                                         | Description                                        |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------------------|----------------------------------------------------------------------------------------------|----------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|
| <b>A10400EC CIS1RoF</b> | <b>CIS1 Register F</b>                                                                       | <b>00000000</b>                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Bit</b>              | 31    30    29    28    27    26    25    24    23    22    21    20    19    18    17    16 |                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Name</b>             | <b>CIS1_WoF</b>                                                                              |                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                           |                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Reset</b>            | 0    0    0    0    0    0    0    0    0    0    0    0    0    0    0    0                 |                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Bit</b>              | 15    14    13    12    11    10    9    8    7    6    5    4    3    2    1    0           |                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Name</b>             | <b>CIS1_WoF</b>                                                                              |                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>             | RW                                                                                           |                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Reset</b>            | 0    0    0    0    0    0    0    0    0    0    0    0    0    0    0    0                 |                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Bit(s)                  | Name                                                                                         | Description                                        |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 21:0                    | CIS1_WoF                                                                                     | CIS1 Register used in ciscc firmware register mode |  |  |  |  |  |  |  |  |  |  |  |  |  |

| A10400Fo CISRDY |         | CIS Ready Flag Register |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 00000000 |   |  |  |
|-----------------|---------|-------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|---|--|--|
| Bit             | 31      | 30                      | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |          |   |  |  |
| Name            | CIS_RDY |                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |   |  |  |
| Type            | RW      |                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |   |  |  |
| Reset           | 0       | 0                       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0        | 0 |  |  |
| Bit             | 15      | 14                      | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |          |   |  |  |
| Name            | CIS_RDY |                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |   |  |  |
| Type            | RW      |                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |   |  |  |
| Reset           | 0       | 0                       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0        | 0 |  |  |

  

| Bit(s) | Name    | Description                                                                                                                    |
|--------|---------|--------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | CIS_RDY | CIS Ready Flag Register that is set after software decodes the CIS and finishes the SA initial flow, to proceed with transfer. |

| Bit(s) | Name  | Description                |
|--------|-------|----------------------------|
| 31:0   | CCCR0 | Card Capability Register 0 |

| <b>A10400F8 CCCR1</b> |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>CC Register 1</b> |   |  |  |
|-----------------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------------|---|--|--|
| Bit                   | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                   |   |  |  |
| <b>Name</b>           | <b>CCCR1</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                      |   |  |  |
| <b>Type</b>           | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                      |   |  |  |
| <b>Reset</b>          | 0            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                    | 0 |  |  |
| <b>Bit</b>            | 15           | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                    |   |  |  |
| <b>Name</b>           | <b>CCCR1</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                      |   |  |  |
| <b>Type</b>           | RW           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                      |   |  |  |
| <b>Reset</b>          | 0            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                    | 0 |  |  |

| Bit(s) | Name  | Description                |
|--------|-------|----------------------------|
| 31:0   | CCCR1 | Card Capability Register 1 |

| <b>A10400FC CCRDY</b> |               |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>CC Ready Flag Register</b> |   |  |  |
|-----------------------|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------------------|---|--|--|
| Bit                   | 31            | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                            |   |  |  |
| <b>Name</b>           | <b>CC_RDY</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                               |   |  |  |
| <b>Type</b>           | RW            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                               |   |  |  |
| <b>Reset</b>          | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                             | 0 |  |  |
| <b>Bit</b>            | 15            | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                             |   |  |  |
| <b>Name</b>           | <b>CC_RDY</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                               |   |  |  |
| <b>Type</b>           | RW            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                               |   |  |  |
| <b>Reset</b>          | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                             | 0 |  |  |

| Bit(s) | Name   | Description                                                    |
|--------|--------|----------------------------------------------------------------|
| 31:0   | CC_RDY | CC Ready Flag Register that is set after the CIS is programmed |

| <b>A1040100 HWFISR</b> |                   |    |    |    |              |    |    |    |               |    |    |    |               |    |    | <b>HIF WLAN Firmware Interrupt Status Register</b> |                  |  |  |  |
|------------------------|-------------------|----|----|----|--------------|----|----|----|---------------|----|----|----|---------------|----|----|----------------------------------------------------|------------------|--|--|--|
| Bit                    | 31                | 30 | 29 | 28 | 27           | 26 | 25 | 24 | 23            | 22 | 21 | 20 | 19            | 18 | 17 | 16                                                 |                  |  |  |  |
| <b>Name</b>            | <b>H2D_SW_INT</b> |    |    |    |              |    |    |    |               |    |    |    |               |    |    |                                                    |                  |  |  |  |
| <b>Type</b>            | W1C               |    |    |    |              |    |    |    |               |    |    |    |               |    |    |                                                    |                  |  |  |  |
| <b>Reset</b>           | 0                 | 0  | 0  | 0  | 0            | 0  | 0  | 0  | 0             | 0  | 0  | 0  | 0             | 0  | 0  | 0                                                  | 0                |  |  |  |
| <b>Bit</b>             | 15                | 14 | 13 | 12 | 11           | 10 | 9  | 8  | 7             | 6  | 5  | 4  | 3             | 2  | 1  | 0                                                  |                  |  |  |  |
| <b>Name</b>            | <b>RX_E</b>       |    |    |    | <b>RX_E</b>  |    |    |    | <b>TX_E</b>   |    |    |    | <b>WR_TI</b>  |    |    |                                                    | <b>RD_HS</b>     |  |  |  |
|                        | <b>VE_NT</b>      |    |    |    | <b>VE_NT</b> |    |    |    | <b>VE_NT</b>  |    |    |    | <b>ME_ME</b>  |    |    |                                                    | <b>M2_R</b>      |  |  |  |
|                        | <b>NT_1</b>       |    |    |    | <b>NT_0</b>  |    |    |    | <b>OU_T_I</b> |    |    |    | <b>T_I_NT</b> |    |    |                                                    | <b>R_FW_I</b>    |  |  |  |
|                        |                   |    |    |    |              |    |    |    |               |    |    |    |               |    |    |                                                    | <b>DR_V_O</b>    |  |  |  |
|                        |                   |    |    |    |              |    |    |    |               |    |    |    |               |    |    |                                                    | <b>DR_V_SE</b>   |  |  |  |
|                        |                   |    |    |    |              |    |    |    |               |    |    |    |               |    |    |                                                    | <b>DR_V_FW</b>   |  |  |  |
|                        |                   |    |    |    |              |    |    |    |               |    |    |    |               |    |    |                                                    | <b>DR_V_O_WN</b> |  |  |  |

| Type      |  |  | RO | RO |  |  |  | RO |  |  |  |  | W1<br>C | W1<br>C | W1<br>C | W1<br>C | W1<br>C |
|-----------|--|--|----|----|--|--|--|----|--|--|--|--|---------|---------|---------|---------|---------|
| Rese<br>t |  |  | o  | o  |  |  |  | o  |  |  |  |  | o       | o       | o       | o       | o       |

| Bit(s) | Name           | Description                                                                                                                                                                                                                                                                                                                                                                 |
|--------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16  | H2D_SW_INT     | <p><b>This field is used for software interrupt for WLAN operation.</b></p> <p>Host driver writes 1s to WSICR [31:16] to set the corresponding bit field.</p>                                                                                                                                                                                                               |
| 13     | RX_EVENT_1     | <p><b>This bit is asserted, if there is any interrupt asserted in HWFRE1SR.</b></p> <p><b>The bit will be de-asserted after software driver clears the interrupt event in HWFRE1SR.</b></p>                                                                                                                                                                                 |
| 12     | RX_EVENT_0     | <p><b>This bit is asserted, if there is any interrupt asserted in HWFREoSR. The bit will be de-asserted after software driver clears the interrupt event in HWFREoSR.</b></p>                                                                                                                                                                                               |
| 8      | TX_EVENT_0     | <p><b>This bit is asserted, if there is any interrupt asserted in HWFTEOoSR. The bit will be de-asserted after software driver clears the interrupt event in HWFTEOoSR.</b></p>                                                                                                                                                                                             |
| 4      | WR_TIMEOUT_INT | <p><b>Write timeout interrupt is triggered, if the host writes data and the device is unable to receive it in a pre-defined period. Firmware should receive the write timeout interrupt and tx_overflow interrupt, simultaneously.</b></p>                                                                                                                                  |
| 3      | RD_TIMEOUT_INT | <p><b>A timeout interrupt is triggered, if the host reads data and the device is unable prepare the data in a pre-defined period. Firmware should receive the read timeout interrupt and rx_underflow interrupt, simultaneously.</b></p>                                                                                                                                    |
| 2      | D2HSM2R_RD_INT | <p><b>This interrupt is set when the host reads the D2HRM2R register.</b></p>                                                                                                                                                                                                                                                                                               |
| 1      | DRV_CLR_FW_OWN | <p><b>This bit is set to 1, if software driver writes 1 into "WHLPCR.FW_OWN_REQ_CLR", to indicate that the software driver requests the control WLAN sub-system from the firmware. The firmware wakes up the WLAN sub-system from sleep mode and writes 1 into HWFICR.FW_OWN_BACK_INT_SET.</b></p> <p>Firmware can clear this bit by writing 1. Writing o does nothing.</p> |
| 0      | DRV_SET_FW_OWN | <p><b>This bit is set to 1, if software driver writes 1 into "WHLPCR.FW_OWN_REQ_SET", to indicate that the software driver transfers the ownership of WLAN sub-system to the firmware. The firmware can force WLAN sub-system into sleep mode.</b></p> <p>Firmware can clear this bit by writing 1. Writing o does nothing.</p>                                             |

A1040104 [HWFIER](#)

HIF WLAN Firmware Interrupt Enable 0oooooooooooo

| Bit    | 31            | 30 | 29                                       | 28                                       | 27 | 26 | 25                                       | 24 | 23 | 22 | 21 | 20                                        | 19                                        | 18                                      | 17                                        | 16 |
|--------|---------------|----|------------------------------------------|------------------------------------------|----|----|------------------------------------------|----|----|----|----|-------------------------------------------|-------------------------------------------|-----------------------------------------|-------------------------------------------|----|
| Name   | H2D_SW_INT_EN |    |                                          |                                          |    |    |                                          |    |    |    |    |                                           |                                           |                                         |                                           |    |
| Type   | RW            |    |                                          |                                          |    |    |                                          |    |    |    |    |                                           |                                           |                                         |                                           |    |
| Rese t | 0             | 0  | 0                                        | 0                                        | 0  | 0  | 0                                        | 0  | 0  | 0  | 0  | 0                                         | 0                                         | 0                                       | 0                                         | 0  |
| Bit    | 15            | 14 | 13                                       | 12                                       | 11 | 10 | 9                                        | 8  | 7  | 6  | 5  | 4                                         | 3                                         | 2                                       | 1                                         | 0  |
| Name   |               |    | RX_E<br>VE<br>NT<br>_1<br>INT<br>_E<br>N | RX_E<br>VE<br>NT<br>_0<br>INT<br>_I<br>N |    |    | TX_E<br>VE<br>NT<br>_0<br>INT<br>_I<br>N |    |    |    |    | WR_TI<br>ME<br>OU<br>T_I<br>NT<br>_E<br>N | RD_TI<br>ME<br>OU<br>T_I<br>NT<br>_E<br>N | D2_M2<br>R_FW<br>_O_WN<br>_I_NT<br>_E_N | DR_V_CL<br>R_FW<br>_O_WN<br>_I_NT<br>_E_N |    |
| Type   |               |    | RW                                       | RW                                       |    |    |                                          | RW |    |    |    | RW                                        | RW                                        | RW                                      | RW                                        | RW |
| Rese t |               |    | 0                                        | 0                                        |    |    |                                          | 0  |    |    |    | 0                                         | 0                                         | 0                                       | 0                                         | 0  |

| Bit(s) | Name                  | Description                                                                                                                                                                         |
|--------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16  | H2D_SW_INT_EN         | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 13     | RX_EVENT_1_INT_EN     | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 12     | RX_EVENT_0_INT_EN     | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 8      | TX_EVENT_0_INT_EN     | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 4      | WR_TIMEOUT_INT_EN     | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 3      | RD_TIMEOUT_INT_EN     | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 2      | D2HSM2R_RD_INT_EN     | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 1      | DRV_CLR_FW_OWN_INT_EN | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 0      | DRV_SET_FW_OWN_INT_EN | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |

| Bit(s) | Name | Description |
|--------|------|-------------|
|--------|------|-------------|

**A1040108 HWFISR1 Reserve for HWFISR1 00000000**

| Bit          | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit          | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit(s) | Name         | Description  |
|--------|--------------|--------------|
| 31:0   | RESV_HWFISR1 | RESV_HWFISR1 |

**A104010C HWFIER1 Reserve for HWFIER1 00000000**

| Bit          | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit          | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit(s) | Name         | Description  |
|--------|--------------|--------------|
| 31:0   | RESV_HWFIER1 | RESV_HWFIER1 |

**A1040110 HWFTEOSR HIF WLAN Firmware TX Event o Status Register 00000000**

| Bit          | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit          | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

|           |  |  |  |  |  |  | <b>ER<br/>FL<br/>OW</b> | <b>ER<br/>FL<br/>OW</b> | <b>Y</b> |
|-----------|--|--|--|--|--|--|-------------------------|-------------------------|----------|----------|----------|----------|----------|----------|----------|----------|
| Type      |  |  |  |  |  |  | W1<br>C                 | W1<br>C                 | W1<br>C  | W1<br>C  | W1<br>C  | W1<br>C  | W1<br>C  | W1<br>C  | W1<br>C  | W1<br>C  |
| Rese<br>t |  |  |  |  |  |  | o                       | o                       | o        | o        | o        | o        | o        | o        | o        | o        |

| <b>Bit(s)</b> | <b>Name</b>     | <b>Description</b>                                                                                                                                                                                                                                     |
|---------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31            | TX7D_LEN_ERR    | <b>TX queue 7 descriptor length error</b><br>A length error interrupt is triggered, when transmitted data amount from the host is greater than the allowed buffer length.                                                                              |
| 30            | TX6D_LEN_ERR    | <b>TX queue 6 descriptor length error</b><br>A length error interrupt is triggered, when transmitted data amount from the host is greater than the allowed buffer length.                                                                              |
| 29            | TX5D_LEN_ERR    | <b>TX queue 5 descriptor length error</b><br>A length error interrupt is triggered, when transmitted data amount from the host is greater than the allowed buffer length.                                                                              |
| 28            | TX4D_LEN_ERR    | <b>TX queue 4 descriptor length error</b><br>A length error interrupt is triggered, when transmitted data amount from the host is greater than the allowed buffer length.                                                                              |
| 27            | TX3D_LEN_ERR    | <b>TX queue 3 descriptor length error</b><br>A length error interrupt is triggered, when transmitted data amount from the host is greater than the allowed buffer length.                                                                              |
| 26            | TX2D_LEN_ERR    | <b>TX queue 2 descriptor length error</b><br>A length error interrupt is triggered, when transmitted data amount from the host is greater than the allowed buffer length.                                                                              |
| 25            | TX1D_LEN_ERR    | <b>TX queue 1 descriptor length error</b><br>A length error interrupt is triggered, when transmitted data amount from the host is greater than the allowed buffer length.                                                                              |
| 24            | TXoD_LEN_ERR    | <b>TX queue 0 descriptor length error</b><br>A length error interrupt is triggered, when transmitted data amount from the host is greater than the allowed buffer length.                                                                              |
| 23            | TX7D_CHKSUM_ERR | <b>TX queue 7 descriptor checksum error</b><br>When HWFCR. TRX_DESC_CHKSUM_EN is enabled; hardware validates the checksum value of each TX descriptor before transferring data. This interrupt is triggered, if TX descriptor checksum error occurred. |
| 22            | TX6D_CHKSUM_ERR | <b>TX queue 6 descriptor checksum error</b><br>When HWFCR. TRX_DESC_CHKSUM_EN is enabled; hardware validates the checksum value of each TX descriptor before transferring data. This interrupt is triggered, if TX descriptor checksum error occurred. |
| 21            | TX5D_CHKSUM_ERR | <b>TX queue 5 descriptor checksum error</b><br>When HWFCR. TRX_DESC_CHKSUM_EN is enabled; hardware validates the checksum value of each TX descriptor before transferring data. This interrupt is triggered, if TX descriptor checksum error occurred. |
| 20            | TX4D_CHKSUM_ERR | <b>TX queue 4 descriptor checksum error</b><br>When HWFCR. TRX_DESC_CHKSUM_EN is enabled; hardware validates the checksum value of each TX descriptor before transferring data. This interrupt is triggered, if TX descriptor checksum error occurred. |
| 19            | TX3D_CHKSUM_ERR | <b>TX queue 3 descriptor checksum error</b><br>When HWFCR. TRX_DESC_CHKSUM_EN is enabled; hardware validates the checksum value of each TX descriptor before transferring data. This interrupt is triggered, if TX descriptor checksum error occurred. |
| 18            | TX2D_CHKSUM_ERR | <b>TX queue 2 descriptor checksum error</b><br>When HWFCR. TRX_DESC_CHKSUM_EN is enabled; hardware validates the checksum value of each TX descriptor before transferring data. This interrupt is triggered, if TX descriptor checksum error occurred. |
| 17            | TX1D_CHKSUM_ERR | <b>TX queue 1 descriptor checksum error</b>                                                                                                                                                                                                            |

| Bit(s) | Name            | Description                                                                                                                                                                                                                                                       |
|--------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16     | TXoD_CHKSUM_ERR | When HWFCR.TRX_DESC_CHKSUM_EN is enabled; hardware validates the checksum value of each TX descriptor before transferring data. This interrupt is triggered, if TX descriptor checksum error occurred.                                                            |
| 9      | TX1_OVERFLOW    | <b>TX queue o descriptor checksum error</b><br>When HWFCR.TRX_DESC_CHKSUM_EN is enabled; hardware validates the checksum value of each TX descriptor before transferring data. This interrupt is triggered, if TX descriptor checksum error occurred.             |
| 8      | TXo_OVERFLOW    | <b>Data overflow at the WLAN TXo port..</b><br>Firmware can clear this bit by writing 1. Writing 0 does nothing.                                                                                                                                                  |
| 7      | TX7_RDY         | <b>Data overflow at the WLAN TX1 port.</b><br>Firmware can clear this bit by writing 1. Writing 0 does nothing.<br><b>Set this bit, if a complete frame is transferred to WLAN TX7 queue from host and the ownership bit of the buffer descriptor is cleared.</b> |
| 6      | TX6_RDY         | Firmware can clear this bit by writing 1. Writing 0 does nothing.<br><b>Set this bit, if a complete frame is transferred to WLAN TX6 queue from host and the ownership bit of the buffer descriptor is cleared.</b>                                               |
| 5      | TX5_RDY         | Firmware can clear this bit by writing 1. Writing 0 does nothing.<br><b>Set this bit, if a complete frame is transferred to WLAN TX5 queue from host and the ownership bit of the buffer descriptor is cleared.</b>                                               |
| 4      | TX4_RDY         | Firmware can clear this bit by writing 1. Writing 0 does nothing.<br><b>Set this bit, if a complete frame is transferred to WLAN TX4 queue from host and the ownership bit of the buffer descriptor is cleared.</b>                                               |
| 3      | TX3_RDY         | Firmware can clear this bit by writing 1. Writing 0 does nothing.<br><b>Set this bit, if a complete frame is transferred to WLAN TX3 queue from host and the ownership bit of the buffer descriptor is cleared.</b>                                               |
| 2      | TX2_RDY         | Firmware can clear this bit by writing 1. Writing 0 does nothing.<br><b>Set this bit, if a complete frame is transferred to WLAN TX2 queue from host and the ownership bit of the buffer descriptor is cleared.</b>                                               |
| 1      | TX1_RDY         | Firmware can clear this bit by writing 1. Writing 0 does nothing.<br><b>Set this bit, if a complete frame is transferred to WLAN TX1 queue from host and the ownership bit of the buffer descriptor is cleared.</b>                                               |
| 0      | TXo_RDY         | Firmware can clear this bit by writing 1. Writing 0 does nothing.<br><b>Set this bit, if a complete frame is transferred to WLAN TXo queue from host and the ownership bit of the buffer descriptor is cleared.</b>                                               |
|        |                 | Firmware can clear this bit by writing 1. Writing 0 does nothing.                                                                                                                                                                                                 |

| A1040114 HWFTE1SR Reserve for HWFTE1SR 00000000 |               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------------------------------------------------|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit                                             | 31            | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name                                            | RESV_HWFTE1SR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                                            | W1C           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset                                           | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |    |
| Bit                                             | 15            | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name                                            | RESV_HWFTE1SR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                                            | W1C           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset                                           | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |    |

| Bit(s) | Name          | Description   |
|--------|---------------|---------------|
| 31:0   | RESV_HWFTE1SR | RESV_HWFTE1SR |

| <b>A1040118 HWFTE2SR</b>    |               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-----------------------------|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Reserve for HWFTE2SR</b> |               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit                         | 31            | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name                        | RESV_HWFTE2SR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                        | W1C           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t                      | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |    |
| Bit                         | 15            | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  |    |
| Name                        | RESV_HWFTE2SR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                        | W1C           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t                      | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |    |

| Bit(s) | Name          | Description   |
|--------|---------------|---------------|
| 31:0   | RESV_HWFTE2SR | RESV_HWFTE2SR |

| <b>A104011C HWFTE3SR</b>    |               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-----------------------------|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Reserve for HWFTE3SR</b> |               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit                         | 31            | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name                        | RESV_HWFTE3SR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                        | W1C           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t                      | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |    |
| Bit                         | 15            | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  |    |
| Name                        | RESV_HWFTE3SR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                        | W1C           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t                      | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |    |

| Bit(s) | Name          | Description   |
|--------|---------------|---------------|
| 31:0   | RESV_HWFTE3SR | RESV_HWFTE3SR |

| <b>A1040120 HWFTEoER</b>                                |                          |                          |                          |                          |                          |                          |                          |                          |                                 |                                 |                                 |                                 |                                 |                                 |                                 |                                 |
|---------------------------------------------------------|--------------------------|--------------------------|--------------------------|--------------------------|--------------------------|--------------------------|--------------------------|--------------------------|---------------------------------|---------------------------------|---------------------------------|---------------------------------|---------------------------------|---------------------------------|---------------------------------|---------------------------------|
| <b>HIF WLAN Firmware TX Event o<br/>Enable Register</b> |                          |                          |                          |                          |                          |                          |                          |                          |                                 |                                 |                                 |                                 |                                 |                                 |                                 |                                 |
| Bit                                                     | 31                       | 30                       | 29                       | 28                       | 27                       | 26                       | 25                       | 24                       | 23                              | 22                              | 21                              | 20                              | 19                              | 18                              | 17                              | 16                              |
| Name                                                    | TX_7D_L_EN_E_RR_I_NT_E_N | TX_6D_L_EN_E_RR_I_NT_E_N | TX_5D_L_EN_E_RR_I_NT_E_N | TX_4D_L_EN_E_RR_I_NT_E_N | TX_3D_L_EN_E_RR_I_NT_E_N | TX_2D_L_EN_E_RR_I_NT_E_N | TX_1D_L_EN_E_RR_I_NT_E_N | TX_0D_L_EN_E_RR_I_NT_E_N | TX_7D_C_HK_E_SU_E_M_ER_I_NT_E_N | TX_6D_C_HK_E_SU_E_M_ER_I_NT_E_N | TX_5D_C_HK_E_SU_E_M_ER_I_NT_E_N | TX_4D_C_HK_E_SU_E_M_ER_I_NT_E_N | TX_3D_C_HK_E_SU_E_M_ER_I_NT_E_N | TX_2D_C_HK_E_SU_E_M_ER_I_NT_E_N | TX_1D_C_HK_E_SU_E_M_ER_I_NT_E_N | TX_oD_C_HK_E_SU_E_M_ER_I_NT_E_N |
| Type                                                    | RW                              | RW                              | RW                              | RW                              | RW                              | RW                              | RW                              |                                 |
| Rese t                                                  | 0                        | 0                        | 0                        | 0                        | 0                        | 0                        | 0                        | 0                        | 0                               | 0                               | 0                               | 0                               | 0                               | 0                               | 0                               |                                 |

| Bit    | 15 | 14 | 13 | 12 | 11 | 10 | 9                                                    | 8                                                    | 7                                          | 6                                          | 5                                          | 4                                          | 3                                          | 2                                          | 1                                    | 0                                    |
|--------|----|----|----|----|----|----|------------------------------------------------------|------------------------------------------------------|--------------------------------------------|--------------------------------------------|--------------------------------------------|--------------------------------------------|--------------------------------------------|--------------------------------------------|--------------------------------------|--------------------------------------|
| Name   |    |    |    |    |    |    | TX<br>1<br>OV<br>ER<br>FL<br>OW<br>I<br>NT<br>E<br>N | TX<br>0<br>OV<br>ER<br>FL<br>OW<br>I<br>NT<br>E<br>N | TX<br>7<br>RD<br>RD<br>Y_I<br>NT<br>E<br>N | TX<br>6<br>RD<br>RD<br>Y_I<br>NT<br>E<br>N | TX<br>5<br>RD<br>RD<br>Y_I<br>NT<br>E<br>N | TX<br>4<br>RD<br>RD<br>Y_I<br>NT<br>E<br>N | TX<br>3<br>RD<br>RD<br>Y_I<br>NT<br>E<br>N | TX<br>2<br>RD<br>RD<br>Y_I<br>NT<br>E<br>N | TX<br>1<br>RD<br>Y_I<br>NT<br>E<br>N | TX<br>0<br>RD<br>Y_I<br>NT<br>E<br>N |
| Type   |    |    |    |    |    |    | RW                                                   | RW                                                   | RW                                         | RW                                         | RW                                         | RW                                         | RW                                         | RW                                         | RW                                   |                                      |
| Rese t |    |    |    |    |    |    | 0                                                    | 0                                                    | 0                                          | 0                                          | 0                                          | 0                                          | 0                                          | 0                                          | 0                                    |                                      |

| Bit(s) | Name                   | Description                                                                                                                                                                         |
|--------|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31     | TX7D_LEN_ERR_INT_EN    | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 30     | TX6D_LEN_ERR_INT_EN    | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 29     | TX5D_LEN_ERR_INT_EN    | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 28     | TX4D_LEN_ERR_INT_EN    | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 27     | TX3D_LEN_ERR_INT_EN    | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 26     | TX2D_LEN_ERR_INT_EN    | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 25     | TX1D_LEN_ERR_INT_EN    | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 24     | TXoD_LEN_ERR_INT_EN    | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 23     | TX7D_CHKSUM_ERR_INT_EN | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 22     | TX6D_CHKSUM_ERR_INT_EN | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 21     | TX5D_CHKSUM_ERR_INT_EN | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.                                                |

| Bit(s) | Name                   | Description                                                                                                                                                                                                                        |
|--------|------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 20     | TX4D_CHKSUM_ERR_INT_EN | 1: Enable the related bit interrupt output.<br><b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 19     | TX3D_CHKSUM_ERR_INT_EN | 1: Enable the related bit interrupt output.<br><b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 18     | TX2D_CHKSUM_ERR_INT_EN | 1: Enable the related bit interrupt output.<br><b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 17     | TX1D_CHKSUM_ERR_INT_EN | 1: Enable the related bit interrupt output.<br><b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 16     | TXoD_CHKSUM_ERR_INT_EN | 1: Enable the related bit interrupt output.<br><b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 9      | TX1_OVERFLOW_INT_EN    | 1: Enable the related bit interrupt output.<br><b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 8      | TXo_OVERFLOW_INT_EN    | 1: Enable the related bit interrupt output.<br><b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 7      | TX7_RDY_INT_EN         | 1: Enable the related bit interrupt output.<br><b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 6      | TX6_RDY_INT_EN         | 1: Enable the related bit interrupt output.<br><b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 5      | TX5_RDY_INT_EN         | 1: Enable the related bit interrupt output.<br><b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 4      | TX4_RDY_INT_EN         | 1: Enable the related bit interrupt output.<br><b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 3      | TX3_RDY_INT_EN         | 1: Enable the related bit interrupt output.<br><b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 2      | TX2_RDY_INT_EN         | 1: Enable the related bit interrupt output.<br><b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 1      | TX1_RDY_INT_EN         | 1: Enable the related bit interrupt output.<br><b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |

| <b>Bit(s)</b> | <b>Name</b>    | <b>Description</b>                                                                                                                                                                  |
|---------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0             | TXo_RDY_INT_EN | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |

| <b>Bit(s)</b> | <b>Name</b>   | <b>Description</b> |
|---------------|---------------|--------------------|
| 31:0          | RESV_HWFTE1ER | RESV_HWFTE1ER      |

| Bit(s) | Name          | Description          |
|--------|---------------|----------------------|
| 31:0   | RESV_HWFTE2ER | <b>RESV_HWFTE2ER</b> |

| Bit(s) | Name          | Description   |
|--------|---------------|---------------|
| 31:0   | RESV_HWFTE3ER | RESV_HWFTE3ER |

| A1040130 <u>HWFREoSR</u> |    | HIF WLAN Firmware RX Event 0 Status Register |    |    |                       |                       |                       |                       |    |    |    |    |                      | oooooooooooo         |                      |                      |  |
|--------------------------|----|----------------------------------------------|----|----|-----------------------|-----------------------|-----------------------|-----------------------|----|----|----|----|----------------------|----------------------|----------------------|----------------------|--|
| Bit                      | 31 | 30                                           | 29 | 28 | 27                    | 26                    | 25                    | 24                    | 23 | 22 | 21 | 20 | 19                   | 18                   | 17                   | 16                   |  |
| Name                     |    |                                              |    |    | RX_L_EN_FO_3_OV_ER_FW | RX_L_EN_FO_2_OV_ER_FW | RX_L_EN_FO_1_OV_ER_FW | RX_L_EN_FO_0_OV_ER_FW |    |    |    |    | RX_3D_C_HK_SU_M_ER_R | RX_2D_C_HK_SU_M_ER_R | RX_1D_C_HK_SU_M_ER_R | RX_0D_C_HK_SU_M_ER_R |  |
| Type                     |    |                                              |    |    | W1_C                  | W1_C                  | W1_C                  | W1_C                  |    |    |    |    | W1_C                 | W1_C                 | W1_C                 | W1_C                 |  |
| Rese t                   |    |                                              |    |    | 0                     | 0                     | 0                     | 0                     |    |    |    |    | 0                    | 0                    | 0                    | 0                    |  |
| Bit                      | 15 | 14                                           | 13 | 12 | 11                    | 10                    | 9                     | 8                     | 7  | 6  | 5  | 4  | 3                    | 2                    | 1                    | 0                    |  |
| Name                     |    |                                              |    |    | RX_3_UN_DE_RF_LO_W    | RX_2_UN_DE_RF_LO_W    | RX_1_UN_DE_RF_LO_W    | RX_0_UN_DE_RF_LO_W    |    |    |    |    | RX_3_DONE            | RX_2_DONE            | RX_1_DONE            | RX_0_DONE            |  |
| Type                     |    |                                              |    |    | W1_C                  | W1_C                  | W1_C                  | W1_C                  |    |    |    |    | W1_C                 | W1_C                 | W1_C                 | W1_C                 |  |
| Rese t                   |    |                                              |    |    | 0                     | 0                     | 0                     | 0                     |    |    |    |    | 0                    | 0                    | 0                    | 0                    |  |

| Bit(s) | Name                  | Description                                                                                                                                                                                                                                                                                                                                                             |
|--------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27     | RX_LEN_FIFO3_OVERFLOW | <p><b>RX length FIFO 3 overflow</b></p> <p>This interrupt is generated whenever the firmware attempts to set RX FIFO length by HWRQ3CR when the packet FIFO length is already full. This leads to FIFO overflow.</p> <p>The entry in packet length FIFO will be pushed-in by firmware, and then popped-out when corresponding RX length is read by the host driver.</p> |
| 26     | RX_LEN_FIFO2_OVERFLOW | <p><b>RX length FIFO 2 overflow</b></p> <p>This interrupt is generated whenever the firmware attempts to set RX FIFO length by HWRQ3CR when the packet FIFO length is already full. This leads to FIFO overflow.</p> <p>The entry in packet length FIFO will be pushed-in by firmware, and then popped-out when corresponding RX length is read by the host driver.</p> |
| 25     | RX_LEN_FIFO1_OVERFLOW | <p><b>RX length FIFO 1 overflow</b></p> <p>This interrupt is generated whenever the firmware attempts to set RX FIFO length by HWRQ3CR when the packet FIFO length is already full. This leads to FIFO overflow.</p> <p>The entry in packet length FIFO will be pushed-in by firmware, and then popped-out when corresponding RX length is read by the host driver.</p> |

| Bit(s) | Name                  | Description                                                                                                                                                                                                                                                                                                                                                                          |
|--------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24     | RX_LEN_FIFOo_OVERFLOW | <p><b>RX length FIFO o overflow</b><br/>           This interrupt is generated whenever the firmware attempts to set RXFIFO length by HWRQ3CR when the packet FIFO length is already full. This leads to FIFO overflow.<br/>           The entry in packet length FIFO will be push-in by firmware, and then popped-out when corresponding RX length is read by the host driver.</p> |
| 19     | RX3D_CHKSUM_ERR       | <p><b>RX 3 descriptor checksum error</b><br/>           When HWFCR. TRX_DESC_CHKSUM_EN is enabled; hardware validates the checksum value of each RX descriptor before transferring the data movement. This interrupt is generated, if RX descriptor checksum error occurred.</p>                                                                                                     |
| 18     | RX2D_CHKSUM_ERR       | <p><b>RX 2 descriptor checksum error</b><br/>           When HWFCR. TRX_DESC_CHKSUM_EN is enabled; hardware validates the checksum value of each RX descriptor before transferring the data. This interrupt is generated if RX descriptor checksum error occurred.</p>                                                                                                               |
| 17     | RX1D_CHKSUM_ERR       | <p><b>RX 1 descriptor checksum error</b><br/>           When HWFCR. TRX_DESC_CHKSUM_EN is enabled; hardware validates the checksum value of each RX descriptor before transferring the data. This interrupt is generated if RX descriptor checksum error occurred.</p>                                                                                                               |
| 16     | RXoD_CHKSUM_ERR       | <p><b>RX o descriptor checksum error</b><br/>           When HWFCR. TRX_DESC_CHKSUM_EN is enabled; hardware validates the checksum value of each RX descriptor before transferring the data. This interrupt is generated if RX descriptor checksum error occurred.</p>                                                                                                               |
| 11     | RX3_UNDERFLOW         | <p><b>Data underflow at the WLAN RX3 port.</b><br/>           Firmware can clear this bit by writing 1. Writing 0 does nothing.</p>                                                                                                                                                                                                                                                  |
| 10     | RX2_UNDERFLOW         | <p><b>Data underflow at the WLAN RX2 port.</b><br/>           Firmware can clear this bit by writing 1. Writing 0 does nothing.</p>                                                                                                                                                                                                                                                  |
| 9      | RX1_UNDERFLOW         | <p><b>Data underflow at the WLAN RX1 port.</b><br/>           Firmware can clear this bit by writing 1. Writing 0 does nothing.</p>                                                                                                                                                                                                                                                  |
| 8      | RXo_UNDERFLOW         | <p><b>Data underflow at the WLAN RXo port.</b><br/>           Firmware can clear this bit by writing 1. Writing 0 does nothing.</p>                                                                                                                                                                                                                                                  |
| 3      | RX3_DONE              | <p><b>Set this bit, if a complete frame is moved to host from WLAN RX3 queue (which also implies the corresponding entry is popped-out from RX3 FIFO length).</b><br/>           Firmware can clear this bit by writing 1. Writing 0 does nothing.</p>                                                                                                                               |
| 2      | RX2_DONE              | <p><b>Set this bit, if a complete frame is moved to host from WLAN RX2 queue (which also implies the corresponding entry is popped-out from RX2 length FIFO).</b><br/>           Firmware can clear this bit by writing 1. Writing 0 does nothing.</p>                                                                                                                               |

| Bit(s) | Name     | Description                                                                                                                                                                                                                         |
|--------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1      | RX1_DONE | <b>Set this bit, if a complete frame is moved to host from WLAN RX1 queue (which also implies the corresponding entry is popped-out from RXo length FIFO).</b><br>Firmware can clear this bit by writing 1. Writing 0 does nothing. |
| 0      | RXo_DONE | <b>Set this bit, if a complete frame is moved to host from WLAN RXo queue (which also implies the corresponding entry is popped-out from RXo length FIFO).</b><br>Firmware can clear this bit by writing 1. Writing 0 does nothing. |

**A1040134 HWFRE1SR**      **HIF WLAN Firmware RX Event 1**      **00000000**  
**Status Register**

| Bit          | 31 | 30 | 29 | 28 | 27                             | 26                             | 25                                 | 24                             | 23 | 22 | 21 | 20 | 19                                               | 18                                               | 17                                               | 16                                               |
|--------------|----|----|----|----|--------------------------------|--------------------------------|------------------------------------|--------------------------------|----|----|----|----|--------------------------------------------------|--------------------------------------------------|--------------------------------------------------|--------------------------------------------------|
| <b>Name</b>  |    |    |    |    |                                |                                |                                    |                                |    |    |    |    |                                                  |                                                  |                                                  |                                                  |
| <b>Type</b>  |    |    |    |    |                                |                                |                                    |                                |    |    |    |    |                                                  |                                                  |                                                  |                                                  |
| <b>Reset</b> |    |    |    |    |                                |                                |                                    |                                |    |    |    |    |                                                  |                                                  |                                                  |                                                  |
| Bit          | 15 | 14 | 13 | 12 | 11                             | 10                             | 9                                  | 8                              | 7  | 6  | 5  | 4  | 3                                                | 2                                                | 1                                                | 0                                                |
| <b>Name</b>  |    |    |    |    | RX<br>3<br>_LE<br>N<br>ER<br>R | RX<br>2<br>_LE<br>N<br>ER<br>R | RX<br>1<br>_L<br>E<br>N<br>E<br>RR | RX<br>0<br>_LE<br>N<br>ER<br>R |    |    |    |    | RX<br>3<br>_OW<br>N<br>CL<br>EA<br>R<br>DO<br>NE | RX<br>2<br>_OW<br>N<br>CL<br>EA<br>R<br>DO<br>NE | RX<br>1<br>_OW<br>N<br>CL<br>EA<br>R<br>DO<br>NE | RX<br>0<br>_OW<br>N<br>CL<br>EA<br>R<br>DO<br>NE |
| <b>Type</b>  |    |    |    |    | W1<br>C                        | W1<br>C                        | W1<br>C                            | W1<br>C                        |    |    |    |    | W1<br>C                                          | W1<br>C                                          | W1<br>C                                          | W1<br>C                                          |
| <b>Reset</b> |    |    |    |    | 0                              | 0                              | 0                                  | 0                              |    |    |    |    | 0                                                | 0                                                | 0                                                | 0                                                |

| Bit(s) | Name               | Description                                                                                                                                                                                                                                             |
|--------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11     | RX3_LEN_ERR        | <b>RX queue 3 descriptor length error</b><br>If the extension length and RX data length are zero in the generic packet descriptor or buffer descriptor, an interrupt is triggered.<br>Firmware can clear this bit by writing 1. Writing 0 does nothing. |
| 10     | RX2_LEN_ERR        | <b>RX queue 2 descriptor length error</b><br>If the extension length and RX data length are zero in the generic packet descriptor or buffer descriptor, an interrupt is triggered.<br>Firmware can clear this bit by writing 1. Writing 0 does nothing. |
| 9      | RX1_LEN_ERR        | <b>RX queue 1 descriptor length error</b><br>If the extension length and RX data length are zero in the generic packet descriptor or buffer descriptor, an interrupt is triggered.<br>Firmware can clear this bit by writing 1. Writing 0 does nothing. |
| 8      | RXo_LEN_ERR        | <b>RX queue o descriptor length error</b><br>If the extension length and RX data length are zero in the generic packet descriptor or buffer descriptor, an interrupt is triggered.<br>Firmware can clear this bit by writing 1. Writing 0 does nothing. |
| 3      | RX3_OWN_CLEAR_DONE | <b>Set this bit, if a complete frame is moved to internal FIFO from WLAN RX3 queue and the ownership bit of the buffer descriptor is cleared.</b><br>Firmware can clear this bit by writing 1. Writing 0 does nothing.                                  |
| 2      | RX2_OWN_CLEAR_DONE | <b>Set this bit, if a complete frame is moved to internal FIFO from WLAN RX2 queue and the ownership bit of the buffer descriptor is cleared.</b><br>Firmware can clear this bit by writing 1. Writing 0 does nothing.                                  |

| <b>Bit(s)</b> | <b>Name</b>        | <b>Description</b>                                                                                                                                                                                                     |
|---------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1             | RX1_OWN_CLEAR_DONE | Firmware can clear this bit by writing 1. Writing 0 does nothing.<br><b>Set this bit, if a complete frame is moved to internal FIFO from WLAN RX1 queue and the ownership bit of the buffer descriptor is cleared.</b> |
| 0             | RXo_OWN_CLEAR_DONE | Firmware can clear this bit by writing 1. Writing 0 does nothing.<br><b>Set this bit, if a complete frame is moved to internal FIFO from WLAN RXo queue and the ownership bit of the buffer descriptor is cleared.</b> |

| Bit(s)          | Name            | Description                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-----------------|-----------------|-----------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| 31:0            | RESV_HWFRE2SR   | RESV_HWFRE2SR               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>A104013C</b> | <b>HWFRE3SR</b> | <b>Reserve for HWFRE3SR</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Bit</b>      | 31              | 30                          | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b>     | RESV_HWFRE3SR   |                             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>     | W1C             |                             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>    | 0               | 0                           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>      | 15              | 14                          | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>     | RESV_HWFRE3SR   |                             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>     | W1C             |                             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>    | 0               | 0                           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

  

| Bit(s) | Name          | Description   |
|--------|---------------|---------------|
| 31:0   | RESV_HWFRE3SR | RESV_HWFRE3SR |

| A1040140 HWFREoER |    |    |    | HIF WLAN Firmware RX Event 0<br>Enable Register |     |     |     |     |    |    |    |    |    | 00000000 |    |    |  |
|-------------------|----|----|----|-------------------------------------------------|-----|-----|-----|-----|----|----|----|----|----|----------|----|----|--|
| Bit               | 31 | 30 | 29 | 28                                              | 27  | 26  | 25  | 24  | 23 | 22 | 21 | 20 | 19 | 18       | 17 | 16 |  |
| Nam e             |    |    |    |                                                 | RX  | RX  | RX  | RX  |    |    |    |    | RX | RX       | RX | RX |  |
|                   |    |    |    |                                                 | L   | L   | L   | L   |    |    |    |    | 3D | 2D       | 1D | 0D |  |
|                   |    |    |    |                                                 | EN  | EN  | EN  | EN  |    |    |    |    | C  | C        | C  | C  |  |
|                   |    |    |    |                                                 | _FI | _FI | _FI | _FI |    |    |    |    | HK | HK       | HK | HK |  |
|                   |    |    |    |                                                 | FO  | FO  | FO  | FO  |    |    |    |    | SU | SU       | SU | SU |  |
|                   |    |    |    |                                                 | 3_  | 2   | 1   | 0   |    |    |    |    | M  | M        | M  | M  |  |
|                   |    |    |    |                                                 | OV  | OV  | OV  | OV  |    |    |    |    | ER | ER       | ER | ER |  |

|                   |    |    |    | <b>ER<br/>FL<br/>OW</b>    | <b>ER<br/>FL<br/>OW</b>    | <b>ER<br/>FL<br/>OW</b>    | <b>ER<br/>FL<br/>OW</b>    |   |   |   |   | <b>R_I<br/>NT<br/>_E<br/>N</b> | <b>R_I<br/>NT<br/>_E<br/>N</b> | <b>R_I<br/>NT<br/>_E<br/>N</b> | <b>R_I<br/>NT<br/>_E<br/>N</b> |                     |
|-------------------|----|----|----|----------------------------|----------------------------|----------------------------|----------------------------|---|---|---|---|--------------------------------|--------------------------------|--------------------------------|--------------------------------|---------------------|
| <b>Type</b>       |    |    |    | RW                         | RW                         | RW                         | RW                         |   |   |   |   | RW                             | RW                             | RW                             | RW                             |                     |
| <b>Rese<br/>t</b> |    |    |    | 0                          | 0                          | 0                          | 0                          |   |   |   |   | 0                              | 0                              | 0                              | 0                              |                     |
| <b>Bit</b>        | 15 | 14 | 13 | 12                         | 11                         | 10                         | 9                          | 8 | 7 | 6 | 5 | 4                              | 3                              | 2                              | 1                              | 0                   |
| <b>Name</b>       |    |    |    | RX_3_UN_DE_RF_LO_W_INT_E_N | RX_2_UN_DE_RF_LO_W_INT_E_N | RX_1_UN_DE_RF_LO_W_INT_E_N | RX_0_UN_DE_RF_LO_W_INT_E_N |   |   |   |   |                                | RX_3_DO_NE_I_NT_E_N            | RX_2_DO_NE_I_NT_E_N            | RX_1_DO_NE_I_NT_E_N            | RX_0_DO_NE_I_NT_E_N |
| <b>Type</b>       |    |    |    | RW                         | RW                         | RW                         | RW                         |   |   |   |   | RW                             | RW                             | RW                             | RW                             |                     |
| <b>Rese<br/>t</b> |    |    |    | 0                          | 0                          | 0                          | 0                          |   |   |   |   | 0                              | 0                              | 0                              | 0                              |                     |

| <b>Bit(s)</b> | <b>Name</b>                  | <b>Description</b>                                                                                                                                                                  |
|---------------|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27            | RX_LEN_FIFO3_OVERFLOW_INT_EN | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 26            | RX_LEN_FIFO2_OVERFLOW_INT_EN | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 25            | RX_LEN_FIFO1_OVERFLOW_INT_EN | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 24            | RX_LEN_FIFOo_OVERFLOW_INT_EN | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 19            | RX3D_CHKSUM_ERR_INT_EN       | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 18            | RX2D_CHKSUM_ERR_INT_EN       | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 17            | RX1D_CHKSUM_ERR_INT_EN       | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 16            | RXoD_CHKSUM_ERR_INT_EN       | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 11            | RX3_UNDERFLOW_INT_EN         | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.                                                |

| Bit(s) | Name                 | Description                                                                                                                                                                                                                        |
|--------|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10     | RX2_UNDERFLOW_INT_EN | 1: Enable the related bit interrupt output.<br><b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 9      | RX1_UNDERFLOW_INT_EN | 1: Enable the related bit interrupt output.<br><b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 8      | RXo_UNDERFLOW_INT_EN | 1: Enable the related bit interrupt output.<br><b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 3      | RX3_DONE_INT_EN      | 1: Enable the related bit interrupt output.<br><b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 2      | RX2_DONE_INT_EN      | 1: Enable the related bit interrupt output.<br><b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 1      | RX1_DONE_INT_EN      | 1: Enable the related bit interrupt output.<br><b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 0      | RXo_DONE_INT_EN      | 1: Enable the related bit interrupt output.<br><b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |

A1040144 HWFRE1ER

HIF WLAN Firmware RX Event 1  
Enable Register

oooooooooooo

| Bit    | 31 | 30 | 29 | 28 | 27      | 26      | 25        | 24      | 23 | 22 | 21 | 20 | 19        | 18        | 17        | 16        |
|--------|----|----|----|----|---------|---------|-----------|---------|----|----|----|----|-----------|-----------|-----------|-----------|
| Nam e  |    |    |    |    |         |         |           |         |    |    |    |    |           |           |           |           |
| Type   |    |    |    |    |         |         |           |         |    |    |    |    |           |           |           |           |
| Rese t |    |    |    |    |         |         |           |         |    |    |    |    |           |           |           |           |
| Bit    | 15 | 14 | 13 | 12 | 11      | 10      | 9         | 8       | 7  | 6  | 5  | 4  | 3         | 2         | 1         | 0         |
| Nam e  |    |    |    |    | RX 3 LE | RX 2 LE | RX 1 L EN | RX 0 LE |    |    |    |    | RX 3 OW N | RX 2 OW N | RX 1 OW N | RX 0 OW N |
| Type   |    |    |    |    | N ER    | N ER    | N E RR    | N E RR  |    |    |    |    | N CL EA   | N CL EA   | N CL EA   | N CL EA   |
| Rese t |    |    |    |    | R I NT  | R I NT  | R I NT    | R I NT  |    |    |    |    | R DO NE   | R DO NE   | R DO NE   | R DO NE   |
|        |    |    |    |    | R E N   | R E N   | R E N     | R E N   |    |    |    |    | R I NT    | R I NT    | R I NT    | R I NT    |
|        |    |    |    |    |         |         |           |         |    |    |    |    | I E N     | I E N     | I E N     | I E N     |
|        |    |    |    |    |         |         |           |         |    |    |    |    |           |           |           |           |
| Type   |    |    |    |    | RW      | RW      | RW        | RW      |    |    |    |    | RW        | RW        | RW        | RW        |
| Rese t |    |    |    |    | 0       | 0       | 0         | 0       |    |    |    |    | 0         | 0         | 0         | 0         |

| Bit(s) | Name | Description |
|--------|------|-------------|
|--------|------|-------------|

| Bit(s) | Name                          | Description                                                                                                                                                                         |
|--------|-------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11     | RX3_LEN_ERR_INT_EN            | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 10     | RX2_LEN_ERR_INT_EN            | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 9      | RX1_LEN_ERR_INT_EN            | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 8      | RXo_LEN_ERR_INT_EN            | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 3      | RX3_OWN_CLEAR_DONE_INT_E<br>N | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 2      | RX2_OWN_CLEAR_DONE_INT_E<br>N | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 1      | RX1_OWN_CLEAR_DONE_INT_E<br>N | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
| 0      | RXo_OWN_CLEAR_DONE_INT_E<br>N | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |

| A1040148 HWFRE2ER |               |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Reserve for HWFRE2ER |   |  |  |
|-------------------|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------------|---|--|--|
| Bit               | 31            | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                   |   |  |  |
| <b>Name</b>       | RESV_HWFRE2ER |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                      |   |  |  |
| <b>Type</b>       | RW            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                      |   |  |  |
| <b>Reset</b>      | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                    | 0 |  |  |
| <b>Bit</b>        | 15            | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                    |   |  |  |
| <b>Name</b>       | RESV_HWFRE2ER |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                      |   |  |  |
| <b>Type</b>       | RW            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                      |   |  |  |
| <b>Reset</b>      | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                    | 0 |  |  |

| Bit(s) | Name          | Description                                                                                                                                                                         |
|--------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | RESV_HWFRE2ER | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |

**A104014C HWFRE3ER****Reserve for HWFRE3ER****oooooooooo**

| Bit   | 31            | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | RESV_HWFRE3ER |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15            | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | RESV_HWFRE3ER |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**Bit(s)****Name****Description**

|      |               |                                                                                                                                                                                     |
|------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 | RESV_HWFRE3ER | <b>WLAN firmware interrupt output control for each bit.</b><br>If the related bit is<br>0: Disable the related bit interrupt output.<br>1: Enable the related bit interrupt output. |
|------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|

**A1040150 HWFICR****HIF WLAN Firmware Interrupt Control Register****oooooooo10**

| Bit   | 31             | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | D2H_SW_INT_SET |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | W1S            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0              | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15             | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | D2H_SW_INT_SET |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | W1S            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0              | 0  | 0  | 0  | 0  | 0  | 0  | 0  |    |    |    |    | 1  |    |    |    |

**Bit(s)****Name****Description**

|      |                |                                                                     |
|------|----------------|---------------------------------------------------------------------|
| 31:8 | D2H_SW_INT_SET | Firmware writes 1s to set WHISR.D2H_SW_INT. Writing 0 does nothing. |
|------|----------------|---------------------------------------------------------------------|

Read always returns 0.

This is used as a communication between firmware and driver, with interrupt trigger to host driver HIF.

## 4 FW\_OWN\_BACK\_INT\_SET

Firmware writes 1 to set WHISR.FW\_OWN\_BACK\_INT. Writing 0 does nothing. It will also clear

WLAN\_FW\_OWN bit and set

WHLPCR.WLAN\_DRV\_OWN bit.

Firmware sets this bit, if the driver requests firmware to return the ownership or the firmware requires to wake up the driver  
Read the bit will get the status of WLAN\_FW\_OWN bit.

WLAN\_FW\_OWN indicates that WLAN firmware has the ownership of the WLAN sub-system.

| Bit(s) | Name | Description                                                                                                                                                                                          |
|--------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |      | This bit is cleared by firmware writing 1 into HWFICR.FW_OWN_BACK_INT_SET or any WLAN driver-domain interrupt.<br>0: WLAN firmware doesn't have any ownership.<br>1: WLAN firmware has an ownership. |

| A1040154 HWFCR |    | HIF WLAN Firmware Control Register 00000000 |    |    |    |              |                 |                       |                       |                        |                        |              |                  |                          |                         |              |
|----------------|----|---------------------------------------------|----|----|----|--------------|-----------------|-----------------------|-----------------------|------------------------|------------------------|--------------|------------------|--------------------------|-------------------------|--------------|
| Bit            | 31 | 30                                          | 29 | 28 | 27 | 26           | 25              | 24                    | 23                    | 22                     | 21                     | 20           | 19               | 18                       | 17                      | 16           |
| Name           |    |                                             |    |    |    |              |                 |                       |                       |                        |                        |              |                  |                          |                         |              |
| Type           |    |                                             |    |    |    |              |                 |                       |                       |                        |                        |              |                  |                          |                         |              |
| Rese t         |    |                                             |    |    |    |              |                 |                       |                       |                        |                        |              |                  |                          |                         |              |
| Bit            | 15 | 14                                          | 13 | 12 | 11 | 10           | 9               | 8                     | 7                     | 6                      | 5                      | 4            | 3                | 2                        | 1                       | 0            |
| Name           |    |                                             |    |    |    | RX_N_O_TAI_L | TX_N_O_HE_AD_ER | RX_U_DP_C_S_OF_LD_E_N | RX_T_CP_C_S_OF_LD_E_N | RX_IP_V4_C_S_OF_LD_E_N | RX_IP_V6_C_S_OF_LD_E_N | RX_OF_LD_E_N | TX_C_S_OF_LD_E_N | TR_X_DE_SC_C_HK_SU_M_12B | TR_X_DE_SC_C_HK_SU_M_EN | W_FU_NC_R_DY |
| Type           |    |                                             |    |    |    | RW           | RW              | RW                    | RW                    | RW                     | RW                     | RW           | RW               | RW                       | RW                      | RW           |
| Rese t         |    |                                             |    |    |    | o            | o               | o                     | o                     | o                      | o                      | o            | o                | o                        | o                       | o            |

| Bit(s) | Name                | Description                                                                                                                                                                                                                                                                                                        |
|--------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9      | RX_NO_TAIL          | <b>RX packet tail is used to send the checksum offload status.</b><br>If the checksum offload hardware is not configured, the tail would be 4B zero. Firmware can write 1 to prevent the RX packet from sending to host.<br>0: RX packet tail will be sent to host.<br>1: RX packet tail will not be sent to host. |
| 8      | TX_NO_HEADER        | <b>Firmware writes 1 to this field so that the host will send the TX packet header instead of writing it to the AHB bus.</b><br>0: TX packet header from host will be written to AHB bus.<br>1: TX packet header from host will not be written to AHB bus.                                                         |
| 7      | RX_UDP_CS_OFLD_EN   | <b>Enable RX UDP checksum verification function</b><br>When enabled, the checksum of RX packet with UDP header is calculated and verified with the field in the original RX packet. The verified status will be padding in the last DWORD of the RX packet.                                                        |
| 6      | RX_TCP_CS_OFLD_EN   | <b>Enable RX TCP checksum verification function</b><br>When enabled, the checksum of RX packet with TCP header is calculated and verified with the field in the original RX packet. The verified status will be padding in the last DWORD of the RX packet.                                                        |
| 5      | RX_IPV4_CS_OFLD_EN  | <b>Enable RX IPv4 checksum verification function</b><br>When enabled, the checksum of RX packet with IPv4 header will be calculated, and verified with the field in original RX packet. The verified status will be padding in the last DWORD of the RX packet.                                                    |
| 4      | RX_IPV6_CS_OFLD_EN  | <b>Enable RX IPv6 checksum (without extension header) verification function</b><br>When enabled, packets checksum of RX packet with IPv6 header will be calculated, and verified with the field in original RX packet. The verified status will be padding in the last DWORD of the RX packet.                     |
| 3      | TX_CS_OFLD_EN       | <b>Enable TX IPV6/IPV4/TCP/UDP checksum generation function</b>                                                                                                                                                                                                                                                    |
| 2      | TRX_DESC_CHKSUM_12B | <b>Firmware write 1 to this filed to change the descriptor</b>                                                                                                                                                                                                                                                     |

| Bit(s) Name          |  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|----------------------|--|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 1 TRX_DESC_CHKSUM_EN |  | <b>checksum calculation method to 12B. The default calculation method is based on the 16B descriptor checksum.</b><br>0: Descriptor checksum calculation is based on first 16B.<br>1: Descriptor checksum calculation is based on first 12B                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0 W_FUNC_RDY         |  | <b>Enable TX/ RX descriptor checksum for debug purpose.</b><br>HW will validate if the summation of descriptor checksum is 0xff before data movement for the descriptor. If it is invalid, corresponding interrupt status (TXD_CHKSUM_ERR/RXD_CHKSUM_ERR) will be generated.<br><b>Indicate the WLAN functional block's current status.</b> If WLAN functional block has finished its initial procedure and it is ready for normal operation, firmware should set this bit. If WLAN functional block was disabled, this bit should be cleared. |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|                      |  | This is a sticky bit of WCIR.W_FUNC_RDY.<br>0: WLAN functional block is not ready for normal operation.<br>1: WLAN functional block is ready for normal operation.                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| A1040158 HWTDCR |                                           | HIF WLAN TX DMA Control Register 00000000 |                                           |                                           |                                           |                                           |                                           |                                           |                                           |                                           |                                           |                                           |                                           |                                           |                                           |                                           |                                          |
|-----------------|-------------------------------------------|-------------------------------------------|-------------------------------------------|-------------------------------------------|-------------------------------------------|-------------------------------------------|-------------------------------------------|-------------------------------------------|-------------------------------------------|-------------------------------------------|-------------------------------------------|-------------------------------------------|-------------------------------------------|-------------------------------------------|-------------------------------------------|-------------------------------------------|------------------------------------------|
| Bit             | 31                                        | 30                                        | 29                                        | 28                                        | 27                                        | 26                                        | 25                                        | 24                                        | 23                                        | 22                                        | 21                                        | 20                                        | 19                                        | 18                                        | 17                                        | 16                                        |                                          |
| Name            | TX<br>Q7<br>D<br>MA<br>S<br>TA<br>TU<br>S | TX<br>Q6<br>D<br>MA<br>S<br>TA<br>TU<br>S | TX<br>Q5<br>D<br>MA<br>S<br>TA<br>TU<br>S | TX<br>Q4<br>D<br>MA<br>S<br>TA<br>TU<br>S | TX<br>Q3<br>D<br>MA<br>S<br>TA<br>TU<br>S | TX<br>Q2<br>D<br>MA<br>S<br>TA<br>TU<br>S | TX<br>Q1<br>D<br>MA<br>S<br>TA<br>TU<br>S | TX<br>Q0<br>D<br>MA<br>S<br>TA<br>TU<br>S | TX<br>Q7<br>D<br>MA<br>S<br>TA<br>TU<br>S | TX<br>Q6<br>D<br>MA<br>S<br>TA<br>TU<br>S | TX<br>Q5<br>D<br>MA<br>S<br>TA<br>TU<br>S | TX<br>Q4<br>D<br>MA<br>S<br>TA<br>TU<br>S | TX<br>Q3<br>D<br>MA<br>S<br>TA<br>TU<br>S | TX<br>Q2<br>D<br>MA<br>S<br>TA<br>TU<br>S | TX<br>Q1<br>D<br>MA<br>S<br>TA<br>TU<br>S | TX<br>Q0<br>D<br>MA<br>S<br>TA<br>TU<br>S | TX<br>Q<br>D<br>MA<br>S<br>TA<br>TU<br>S |
| Type            | RO                                        | W1S                                       |                                          |
| Reset           | 0                                         | 0                                         | 0                                         | 0                                         | 0                                         | 0                                         | 0                                         | 0                                         | 0                                         | 0                                         | 0                                         | 0                                         | 0                                         | 0                                         | 0                                         | 0                                         |                                          |
| Bit             | 15                                        | 14                                        | 13                                        | 12                                        | 11                                        | 10                                        | 9                                         | 8                                         | 7                                         | 6                                         | 5                                         | 4                                         | 3                                         | 2                                         | 1                                         | 0                                         |                                          |
| Name            | TX<br>Q7<br>D<br>MA<br>S<br>TA<br>RT      | TX<br>Q6<br>D<br>MA<br>S<br>TA<br>RT      | TX<br>Q5<br>D<br>MA<br>S<br>TA<br>RT      | TX<br>Q4<br>D<br>MA<br>S<br>TA<br>RT      | TX<br>Q3<br>D<br>MA<br>S<br>TA<br>RT      | TX<br>Q2<br>D<br>MA<br>S<br>TA<br>RT      | TX<br>Q1<br>D<br>MA<br>S<br>TA<br>RT      | TX<br>Q0<br>D<br>MA<br>S<br>TA<br>RT      | TX<br>Q7<br>D<br>MA<br>S<br>TO<br>P       | TX<br>Q6<br>D<br>MA<br>S<br>TO<br>P       | TX<br>Q5<br>D<br>MA<br>S<br>TO<br>P       | TX<br>Q4<br>D<br>MA<br>S<br>TO<br>P       | TX<br>Q3<br>D<br>MA<br>S<br>TO<br>P       | TX<br>Q2<br>D<br>MA<br>S<br>TO<br>P       | TX<br>Q1<br>D<br>MA<br>S<br>TO<br>P       | TX<br>Q0<br>D<br>MA<br>S<br>TO<br>P       |                                          |
| Type            | W1S                                       |                                          |
| Reset           | 0                                         | 0                                         | 0                                         | 0                                         | 0                                         | 0                                         | 0                                         | 0                                         | 0                                         | 0                                         | 0                                         | 0                                         | 0                                         | 0                                         | 0                                         | 0                                         |                                          |

| Bit(s) Name |                 | Description                                                                                                                                                                                                                                                                                                                                                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| 31          | TXQ7_DMA_STATUS | <b>Read for the TX4 queue DMA status.</b><br>When the HIF Controller is reset, the queue is in the inactive state by default. After receiving a START or RESUME command and executing it without error, the queue enters the active state. When the queue is empty or stopped by a STOP command, it returns to the inactive state.<br>0: inactive<br>1: active |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 30          | TXQ6_DMA_STATUS | <b>Read for the TX6 queue DMA status.</b><br>When the HIF Controller is reset, the queue is in the inactive state by default. After receiving a START or RESUME command and executing it without error, the queue enters the active state. When the queue is empty or stopped by a STOP command, it returns to                                                 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| <b>Bit(s)</b> | <b>Name</b>     | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                   |
|---------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29            | TXQ5_DMA_STATUS | <p>the inactive state.<br/>0: inactive<br/>1: active</p> <p><b>Read for the TX5 queue DMA status.</b><br/>When the HIF Controller is reset, the queue is in the inactive state by default. After receiving a START or RESUME command and executing it without error, the queue enters the active state. When the queue is empty or stopped by a STOP command, it returns to the inactive state.</p> <p>0: inactive<br/>1: active</p> |
| 28            | TXQ4_DMA_STATUS | <p><b>Read for the TX4 queue DMA status.</b><br/>When the HIF Controller is reset, the queue is in the inactive state by default. After receiving a START or RESUME command and executing it without error, the queue enters the active state. When the queue is empty or stopped by a STOP command, it returns to the inactive state.</p> <p>0: inactive<br/>1: active</p>                                                          |
| 27            | TXQ3_DMA_STATUS | <p><b>Read for the TX3 queue DMA status.</b><br/>When the HIF Controller is reset, the queue is in the inactive state by default. After receiving a START or RESUME command and executing it without error, the queue enters the active state. When the queue is empty or stopped by a STOP command, it returns to the inactive state.</p> <p>0: inactive<br/>1: active</p>                                                          |
| 26            | TXQ2_DMA_STATUS | <p><b>Read for the TX2 queue DMA status.</b><br/>When the HIF Controller is reset, the queue is in the inactive state by default. After receiving a START or RESUME command and executing it without error, the queue enters the active state. When the queue is empty or stopped by a STOP command, it returns to the inactive state.</p> <p>0: inactive<br/>1: active</p>                                                          |
| 25            | TXQ1_DMA_STATUS | <p><b>Read for the TX1 queue DMA status.</b><br/>When the HIF Controller is reset, the queue is in the inactive state by default. After receiving a START or RESUME command and executing it without error, the queue enters the active state. When the queue is empty or stopped by a STOP command, it returns to the inactive state.</p> <p>0: inactive<br/>1: active</p>                                                          |
| 24            | TXQ0_DMA_STATUS | <p><b>Read for the TX0 queue DMA status.</b><br/>When the HIF Controller is reset, the queue is in the inactive state by default. After receiving a START or RESUME command and executing it without error, the queue enters the active state. When the queue is empty or stopped by a STOP command, it returns to the inactive state.</p> <p>0: inactive<br/>1: active</p>                                                          |
| 23            | TXQ7_DMA_RUM    | <p><b>Resume the TX7 queue DMA to operate.</b><br/>The DMA will reload the chain descriptor from the current address. Firmware writes 1 to enable the DMA. Writing 0 does nothing. Read always returns 0.</p>                                                                                                                                                                                                                        |
| 22            | TXQ6_DMA_RUM    | <p><b>Resume the TX6 queue DMA to operate.</b><br/>The DMA will reload the chain descriptor from the current address. Firmware writes 1 to enable the DMA. Writing 0 does nothing. Read always returns 0.</p>                                                                                                                                                                                                                        |
| 21            | TXQ5_DMA_RUM    | <p><b>Resume the TX5 queue DMA to operate.</b></p>                                                                                                                                                                                                                                                                                                                                                                                   |

| Bit(s) | Name           | Description                                                                                                                                                                                                                        |
|--------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 20     | TXQ4_DMA_RUM   | The DMA will reload the chain descriptor from the current address. Firmware writes 1 to enable the DMA. Writing 0 does nothing. Read always returns 0.<br><b>Resume the TX4 queue DMA to operate.</b>                              |
| 19     | TXQ3_DMA_RUM   | The DMA will reload the chain descriptor from the current address. Firmware writes 1 to enable the DMA. Writing 0 does nothing. Read always returns 0.<br><b>Resume the TX3 queue DMA to operate.</b>                              |
| 18     | TXQ2_DMA_RUM   | The DMA will reload the chain descriptor from the current address. Firmware writes 1 to enable the DMA. Writing 0 does nothing. Read always returns 0.<br><b>Resume the TX2 queue DMA to operate.</b>                              |
| 17     | TXQ1_DMA_RUM   | The DMA will reload the chain descriptor from the current address. Firmware writes 1 to enable the DMA. Writing 0 does nothing. Read always returns 0.<br><b>Resume the TX1 queue DMA to operate.</b>                              |
| 16     | TXQ0_DMA_RUM   | The DMA will reload the chain descriptor from the current address. Firmware writes 1 to enable the DMA. Writing 0 does nothing. Read always returns 0.<br><b>Resume the TX0 queue DMA to operate.</b>                              |
| 15     | TXQ7_DMA_START | The DMA will load the chain descriptor from the address assigned by HWFTQ7SAR. SW must check TXQ7_DMA_STATUS is inactive before start. Writing 0 does nothing. Read always returns 0.<br><b>Start the TX7 queue DMA operation.</b> |
| 14     | TXQ6_DMA_START | The DMA will load the chain descriptor from the address assigned by HWFTQ6SAR. SW must check TXQ6_DMA_STATUS is inactive before start. Writing 0 does nothing. Read always returns 0.<br><b>Start the TX6 queue DMA operation.</b> |
| 13     | TXQ5_DMA_START | The DMA will load the chain descriptor from the address assigned by HWFTQ5SAR. SW must check TXQ5_DMA_STATUS is inactive before start. Writing 0 does nothing. Read always returns 0.<br><b>Start the TX5 queue DMA operation.</b> |
| 12     | TXQ4_DMA_START | The DMA will load the chain descriptor from the address assigned by HWFTQ4SAR. SW must check TXQ4_DMA_STATUS is inactive before start. Writing 0 does nothing. Read always returns 0.<br><b>Start the TX4 queue DMA operation.</b> |
| 11     | TXQ3_DMA_START | The DMA will load the chain descriptor from the address assigned by HWFTQ3SAR. SW must check TXQ3_DMA_STATUS is inactive before start. Writing 0 does nothing. Read always returns 0.<br><b>Start the TX3 queue DMA operation.</b> |
| 10     | TXQ2_DMA_START | The DMA will load the chain descriptor from the address assigned by HWFTQ2SAR. SW must check TXQ2_DMA_STATUS is inactive before start. Writing 0 does nothing. Read always returns 0.<br><b>Start the TX2 queue DMA operation.</b> |
| 9      | TXQ1_DMA_START | The DMA will load the chain descriptor from the address assigned by HWFTQ1SAR. SW must check TXQ1_DMA_STATUS is inactive before start. Writing 0 does nothing. Read always returns 0.<br><b>Start the TX1 queue DMA operation.</b> |
| 8      | TXQ0_DMA_START | The DMA will load the chain descriptor from the address assigned by HWFTQ0SAR. SW must check TXQ0_DMA_STATUS is inactive before start. Writing 0 does nothing. Read always returns 0.<br><b>Start the TX0 queue DMA operation.</b> |

| Bit(s) | Name          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|--------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7      | TXQ7_DMA_STOP | <b>Stop the TX7 queue DMA operation. It will NOT clear the result of TX count set by HWTPCCR(WTSRo/ WTSR1).</b><br>Firmware writes 1 to stop the DMA. Writing 0 does nothing.<br>Read always returns current DMA activity (0: stopped, 1: stop command is on-going).<br>If one data port to multiple queues design is configured, any one of these queues stop would lead to these queues stop at the same time. (e.g. If TX queue 1 stops, then TX queue 2, 3, 4, 5, 6, 7 would also be stopped by HW since they share the same data port.) |
| 6      | TXQ6_DMA_STOP | <b>Stop the TX6 queue DMA operation. It will NOT clear the result of TX count set by HWTPCCR(WTSRo/ WTSR1).</b><br>Firmware writes 1 to stop the DMA. Writing 0 does nothing.<br>Read always returns current DMA activity (0: stopped, 1: stop command is on-going).<br>If one data port to multiple queues design is configured, any one of these queues stop would lead to these queues stop at the same time. (e.g. If TX queue 1 stops, then TX queue 2, 3, 4, 5, 6, 7 would also be stopped by HW since they share the same data port.) |
| 5      | TXQ5_DMA_STOP | <b>Stop the TX5 queue DMA operation. It will NOT clear the result of TX count set by HWTPCCR(WTSRo/ WTSR1).</b><br>Firmware writes 1 to stop the DMA. Writing 0 does nothing.<br>Read always returns current DMA activity (0: stopped, 1: stop command is on-going).<br>If one data port to multiple queues design is configured, any one of these queues stop would lead to these queues stop at the same time. (e.g. If TX queue 1 stops, then TX queue 2, 3, 4, 5, 6, 7 would also be stopped by HW since they share the same data port.) |
| 4      | TXQ4_DMA_STOP | <b>Stop the TX4 queue DMA operation. It will NOT clear the result of TX count set by HWTPCCR(WTSRo/ WTSR1).</b><br>Firmware writes 1 to stop the DMA. Writing 0 does nothing.<br>Read always returns current DMA activity (0: stopped, 1: stop command is on-going).<br>If one data port to multiple queues design is configured, any one of these queues stop would lead to these queues stop at the same time. (e.g. If TX queue 1 stops, then TX queue 2, 3, 4, 5, 6, 7 would also be stopped by HW since they share the same data port.) |
| 3      | TXQ3_DMA_STOP | <b>Stop the TX3 queue DMA operation. It will NOT clear the result of TX count set by HWTPCCR(WTSRo/ WTSR1).</b><br>Firmware writes 1 to stop the DMA. Writing 0 does nothing.<br>Read always returns current DMA activity (0: stopped, 1: stop command is on-going).<br>If one data port to multiple queues design is configured, any one of these queues stop would lead to these queues stop at the same time. (e.g. If TX queue 1 stops, then TX queue 2, 3, 4, 5, 6, 7 would also be stopped by HW since they share the same data port.) |
| 2      | TXQ2_DMA_STOP | <b>Stop the TX2 queue DMA operation. It will NOT clear the result of TX count set by HWTPCCR(WTSRo/ WTSR1).</b><br>Firmware writes 1 to stop the DMA. Writing 0 does nothing.<br>Read always returns current DMA activity (0: stopped, 1: stop command is on-going).<br>If one data port to multiple queues design is configured, any one of these queues stop would lead to these queues stop at the same time. (e.g. If TX queue 1 stops, then TX queue 2, 3, 4, 5, 6, 7 would also be stopped by HW since they share the same data port.) |
| 1      | TXQ1_DMA_STOP | <b>Stop the TX1 queue DMA operation. It will NOT clear the result of TX count set by HWTPCCR(WTSRo/ WTSR1).</b><br>Firmware writes 1 to stop the DMA. Writing 0 does nothing.<br>Read always returns current DMA activity (0: stopped, 1: stop command is on-going).<br>If one data port to multiple queues design is configured, any one of these queues stop would lead to these queues stop at the same time. (e.g. If TX queue 1 stops, then TX queue 2, 3, 4, 5, 6, 7 would also be stopped by HW since they share the same data port.) |

| Bit(s) | Name          | Description                                                                                                                                                                                                                                                          |
|--------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | TXQo_DMA_STOP | <b>Stop the TXo queue DMA operation. It will NOT clear the result of TX count set by HWTPCCR(WTSRo/ WTSR1).</b><br>Firmware writes 1 to stop the DMA. Writing 0 does nothing.<br>Read always returns current DMA activity (0: stopped, 1: stop command is on-going). |

**A104015C HWTPCCR HIF WLAN TX Packet Count Control Register 00000000**

| Bit   | 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22         | 21 | 20 | 19 | 18 | 17                             | 16  |
|-------|----------|----|----|----|----|----|----|----|----|------------|----|----|----|----|--------------------------------|-----|
| Name  |          |    |    |    |    |    |    |    |    |            |    |    |    |    | TQ<br>C<br>NT<br>R<br>ES<br>ET |     |
| Type  |          |    |    |    |    |    |    |    |    |            |    |    |    |    |                                | W1S |
| Reset |          |    |    |    |    |    |    |    |    |            |    |    |    |    |                                | 0   |
| Bit   | 15       | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6          | 5  | 4  | 3  | 2  | 1                              | 0   |
| Name  | TQ_INDEX |    |    |    |    |    |    |    |    | INC_TQ_CNT |    |    |    |    |                                |     |
| Type  | WO       |    |    |    |    |    |    |    |    | WO         |    |    |    |    |                                |     |
| Reset | 0        | 0  | 0  | 0  |    |    |    |    |    | 0          | 0  | 0  | 0  | 0  | 0                              | 0   |

| Bit(s) | Name         | Description                                                                                                                                                                                                        |
|--------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16     | TQ_CNT_RESET | <b>Firmware writes 1 to reset the count accumulated for TQo ~ TQ7.</b><br>Writing 0 does nothing. Read always returns 0.                                                                                           |
| 15:12  | TQ_INDEX     | <b>Firmware writes the TQ index to be increased by setting this field which leads to the same number increased in WTSR.TQX_CNT.</b><br>Writing 0 does nothing. Read always returns 0. (X depends on the TQ index)  |
| 7:0    | INC_TQ_CNT   | <b>Firmware writes the available TQ buffer count by setting this field which leads to the same number increased in WTSR.TQX_CNT.</b><br>Writing 0 does nothing. Read always returns 0. (X depends on the TQ index) |

**A1040160 HWFTQoSAR HIF WLAN Firmware TX Queue o Start Address Register 00000000**

| Bit   | 31                  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | WLAN_TXQo_DMA_SADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15                  | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | WLAN_TXQo_DMA_SADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name                | Description                                                   |
|--------|---------------------|---------------------------------------------------------------|
| 31:2   | WLAN_TXQo_DMA_SADDR | The start address of buffer chain of TXo queue in unit of DW. |

**A1040164 HWFTQ1SAR HIF WLAN Firmware TX Queue 1 Start Address Register 0oooooooooooo**

| Bit    | 31                  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name   | WLAN_TXQ1_DMA_SADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type   | RW                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t | 0                   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit    | 15                  | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name   | WLAN_TXQ1_DMA_SADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type   | RW                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t | 0                   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name                | Description                                                   |
|--------|---------------------|---------------------------------------------------------------|
| 31:2   | WLAN_TXQ1_DMA_SADDR | The start address of buffer chain of TX1 queue in unit of DW. |

**A1040168 HWFTQ2SAR HIF WLAN Firmware TX Queue 2 Start Address Register 0oooooooooooo**

| Bit    | 31                  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name   | WLAN_TXQ2_DMA_SADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type   | RW                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t | 0                   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit    | 15                  | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name   | WLAN_TXQ2_DMA_SADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type   | RW                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t | 0                   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name                | Description                                                   |
|--------|---------------------|---------------------------------------------------------------|
| 31:2   | WLAN_TXQ2_DMA_SADDR | The start address of buffer chain of TX2 queue in unit of DW. |

**A104016C HWFTQ3SAR HIF WLAN Firmware TX Queue 3 Start Address Register 0oooooooooooo**

| Bit    | 31                  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name   | WLAN_TXQ3_DMA_SADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type   | RW                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t | 0                   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit    | 15                  | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name   | WLAN_TXQ3_DMA_SADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Type   | RW |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |  |
|--------|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|--|--|
| Rese t | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |  |

| Bit(s) | Name                | Description                                                   |
|--------|---------------------|---------------------------------------------------------------|
| 31:2   | WLAN_TXQ3_DMA_SADDR | The start address of buffer chain of TX3 queue in unit of DW. |

**A1040170 HWFTQ4SAR**      **HIF WLAN Firmware TX Queue 4 Start Address Register**      **oooooooooooo**

| Bit    | 31                  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name   | WLAN_TXQ4_DMA_SADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type   | RW                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t | 0                   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit    | 15                  | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name   | WLAN_TXQ4_DMA_SADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type   | RW                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t | 0                   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name                | Description                                                   |
|--------|---------------------|---------------------------------------------------------------|
| 31:2   | WLAN_TXQ4_DMA_SADDR | The start address of buffer chain of TX4 queue in unit of DW. |

**A1040174 HWFTQ5SAR**      **Reserve for HIF WLAN Firmware TX Queue 5 Start Address Register**      **oooooooooooo**

| Bit    | 31                  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name   | WLAN_TXQ5_DMA_SADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type   | RW                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t | 0                   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit    | 15                  | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name   | WLAN_TXQ5_DMA_SADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type   | RW                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t | 0                   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name                | Description                                                   |
|--------|---------------------|---------------------------------------------------------------|
| 31:2   | WLAN_TXQ5_DMA_SADDR | The start address of buffer chain of TX5 queue in unit of DW. |

**A1040178 HWFTQ6SAR**      **Reserve for HIF WLAN Firmware TX Queue 6 Start Address Register**      **oooooooooooo**

| Bit  | 31                  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name | WLAN_TXQ6_DMA_SADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type | RW                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

|        |                     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |   |
|--------|---------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|---|
| Rese t | 0                   | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Bit    | 15                  | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |   |
| Name   | WLAN_TXQ6_DMA_SADDR |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |   |
| Type   | RW                  |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |   |
| Rese t | 0                   | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |

| Bit(s) | Name                | Description                                                   |
|--------|---------------------|---------------------------------------------------------------|
| 31:2   | WLAN_TXQ6_DMA_SADDR | The start address of buffer chain of TX6 queue in unit of DW. |

**A104017C HWFTQ7SAR Reserve for HIF WLAN Firmware TX Queue 7 Start Address Register 0ooooooooo**

|        |                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|--------|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit    | 31                  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name   | WLAN_TXQ7_DMA_SADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type   | RW                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t | 0                   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit    | 15                  | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name   | WLAN_TXQ7_DMA_SADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type   | RW                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t | 0                   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name                | Description                                                   |
|--------|---------------------|---------------------------------------------------------------|
| 31:2   | WLAN_TXQ7_DMA_SADDR | The start address of buffer chain of TX7 queue in unit of DW. |

**A1040180 HWFRQoSAR HIF WLAN Firmware RX Queue 0 Start Address Register 0ooooooooo**

|        |                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|--------|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit    | 31                  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name   | WLAN_RXQ0_DMA_SADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type   | RW                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t | 0                   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit    | 15                  | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name   | WLAN_RXQ0_DMA_SADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type   | RW                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t | 0                   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name                | Description                                                   |
|--------|---------------------|---------------------------------------------------------------|
| 31:2   | WLAN_RXQ0_DMA_SADDR | The start address of buffer chain of RX0 queue in unit of DW. |

**A1040184 HWFRQ1SAR HIF WLAN Firmware RX Queue 1 Start 0ooooooooo**

**Address Register**

| <b>Bit</b>   | 31                         | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|----------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  | <b>WLAN_RXQ1_DMA_SADDR</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>   | 15                         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | <b>WLAN_RXQ1_DMA_SADDR</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| <b>Bit(s)</b> | <b>Name</b>         | <b>Description</b>                                            |
|---------------|---------------------|---------------------------------------------------------------|
| 31:2          | WLAN_RXQ1_DMA_SADDR | The start address of buffer chain of RX1 queue in unit of DW. |

**A1040188 HWFRQ2SAR HIF WLAN Firmware RX Queue 2 Start 00000000 Address Register**

| <b>Bit</b>   | 31                         | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|----------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  | <b>WLAN_RXQ2_DMA_SADDR</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>   | 15                         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | <b>WLAN_RXQ2_DMA_SADDR</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| <b>Bit(s)</b> | <b>Name</b>         | <b>Description</b>                                            |
|---------------|---------------------|---------------------------------------------------------------|
| 31:2          | WLAN_RXQ2_DMA_SADDR | The start address of buffer chain of RX2 queue in unit of DW. |

**A104018C HWFRQ3SAR HIF WLAN Firmware RX Queue 3 Start 00000000 Address Register**

| <b>Bit</b>   | 31                         | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|----------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  | <b>WLAN_RXQ3_DMA_SADDR</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>   | 15                         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | <b>WLAN_RXQ3_DMA_SADDR</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| <b>Bit(s)</b> | <b>Name</b>         | <b>Description</b>                                        |
|---------------|---------------------|-----------------------------------------------------------|
| 31:2          | WLAN_RXQ3_DMA_SADDR | The start address of buffer chain of RX3 queue in unit of |

| Bit(s) | Name | Description |
|--------|------|-------------|
|        | DW.  |             |

**A1040190 HWFRQ4SAR Reserve for HIF WLAN Firmware RX Queue 4 Start Address Register 00000000**

| Bit   | 31                         | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | <b>WLAN_RXQ4_DMA_SADDR</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15                         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>WLAN_RXQ4_DMA_SADDR</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name                | Description                                                   |
|--------|---------------------|---------------------------------------------------------------|
| 31:2   | WLAN_RXQ4_DMA_SADDR | The start address of buffer chain of RX4 queue in unit of DW. |

**A1040194 HWFRQ5SAR Reserve for HIF WLAN Firmware RX Queue 5 Start Address Register 00000000**

| Bit   | 31                         | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | <b>WLAN_RXQ5_DMA_SADDR</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15                         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>WLAN_RXQ5_DMA_SADDR</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name                | Description                                                   |
|--------|---------------------|---------------------------------------------------------------|
| 31:2   | WLAN_RXQ5_DMA_SADDR | The start address of buffer chain of RX5 queue in unit of DW. |

**A1040198 HWFRQ6SAR Reserve for HIF WLAN Firmware RX Queue 6 Start Address Register 00000000**

| Bit   | 31                         | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | <b>WLAN_RXQ6_DMA_SADDR</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15                         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>WLAN_RXQ6_DMA_SADDR</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Type  | RW |   |   |   |   |   |   |   |   |   |   |   |   |   |   |  |  |
|-------|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|--|--|
| Reset | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |  |

| Bit(s) | Name                | Description                                                   |
|--------|---------------------|---------------------------------------------------------------|
| 31:2   | WLAN_RXQ6_DMA_SADDR | The start address of buffer chain of RX6 queue in unit of DW. |

**A104019C HWFRQ7SAR** Reserve for HIF WLAN Firmware RX Queue 7 Start Address Register **oooooooooooo**

| Bit                 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Reset               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| WLAN_RXQ7_DMA_SADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit                 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Reset               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| WLAN_RXQ7_DMA_SADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit                 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reset               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name                | Description                                                   |
|--------|---------------------|---------------------------------------------------------------|
| 31:2   | WLAN_RXQ7_DMA_SADDR | The start address of buffer chain of RX7 queue in unit of DW. |

**A10401A0 H2DRMoR** Host to Device Receive Mailbox 0 Register **oooooooooooo**

| Bit     | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|---------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Reset   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| H2D_RMo |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit     | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Reset   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| H2D_RMo |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit     | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reset   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name    | Description                                                                                                              |
|--------|---------|--------------------------------------------------------------------------------------------------------------------------|
| 31:0   | H2D_RMo | This register is used by firmware to receive data from SDIO controller, which is updated through H2DSMoR by host driver. |

**A10401A4 H2DRM1R** Host to Device Receive Mailbox 1 Register **oooooooooooo**

| Bit     | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|---------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Reset   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| H2D_RM1 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit     | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Reset   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name    | Description                                                                                                              |
|--------|---------|--------------------------------------------------------------------------------------------------------------------------|
| 31:0   | H2D_RM1 | This register is used by firmware to receive data from SDIO controller, which is updated through H2DSM1R by host driver. |

| <b>A10401A8 D2HSMoR</b> |                | <b>Device to Host Send Mailbox o Register</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |  | oooooooooooo |  |  |  |  |  |  |  |  |
|-------------------------|----------------|-----------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--|--------------|--|--|--|--|--|--|--|--|
| <b>Bit</b>              | 31             | 30                                            | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |  |              |  |  |  |  |  |  |  |  |
| <b>Name</b>             | <b>D2H_SMo</b> |                                               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |  |              |  |  |  |  |  |  |  |  |
| <b>Type</b>             | <b>RW</b>      |                                               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |  |              |  |  |  |  |  |  |  |  |
| <b>Reset</b>            | 0              | 0                                             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |  |              |  |  |  |  |  |  |  |  |
| <b>Bit</b>              | 15             | 14                                            | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |  |              |  |  |  |  |  |  |  |  |
| <b>Name</b>             | <b>D2H_SMo</b> |                                               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |  |              |  |  |  |  |  |  |  |  |
| <b>Type</b>             | <b>RW</b>      |                                               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |  |              |  |  |  |  |  |  |  |  |
| <b>Reset</b>            | 0              | 0                                             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |  |              |  |  |  |  |  |  |  |  |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                                                                                            |
|---------------|-------------|-------------------------------------------------------------------------------------------------------------------------------|
| 31:0          | D2H_SMo     | This register is used by firmware to transmit data to SDIO controller, it will be updated to D2HRMOR and read by host driver. |

| Bit(s) | Name    | Description                                                                                                                   |
|--------|---------|-------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | D2H_SM1 | This register is used by firmware to transmit data to SDIO controller, it will be updated to D2HRM1R and read by host driver. |

**A10401Bo D2HSM2R Device to Host Send Mailbox 2 Register 0ooooooooo**

| Bit          | 31             | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  | <b>D2H_SM2</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0              | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit          | 15             | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |

| Bit(s) | Name    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | D2H_SM2 | <p><b>This register is used by firmware to transmit data to SDIO controller, it will be updated to D2HRM2R and read by host driver.</b></p> <p>When reading this register, it may not get the value that firmware just writes, it may read the older value that firmware had written before. It results from the synchronization issue of hardware.</p> <p>Firmware would get the value that host is tending to read when host clock turns on.</p> <p>Note that host driver could read D2HRM2R without system AHB clock. Hence, after firmware set this register, MCU could turn off system AHB clock to save power if necessary.</p> |

| A10401Co <u>HWRQoCR</u> HIF WLAN RX Queue o Control Register 00000000 |                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-----------------------------------------------------------------------|---------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit                                                                   | 31                        | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b>                                                           |                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                                                           |                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                                                          |                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit                                                                   | 15                        | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>                                                           | <b>RXQo_PACKET_LENGTH</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                                                           | RW                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                                                          | 0                         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name            | Description                                                                                                                                                                                                                                                                                                                                                                     |
|--------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19     | RXQo_DMA_STATUS | <p><b>Read for the RXo queue DMA status.</b></p> <p>When the SDIO Controller is reset, the queue is in the inactive state by default. After receiving a START or RESUME command and executing it without error, the queue enters the active state. When the queue is empty or stopped by a STOP command, it returns to the inactive state.</p> <p>0: inactive<br/>1: active</p> |
| 18     | RXQo_DMA_RUM    | <p><b>Resume the RXo queue DMA to operate.</b></p> <p>The DMA will reload the chain descriptor from the current address. Firmware writes 1 to enable the DMA. Writing 0 does nothing.</p>                                                                                                                                                                                       |

| Bit(s) | Name               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17     | RXQo_DMA_START     | <p>Read always returns 0.</p> <p><b>Start the RXo queue DMA operation.</b></p> <p>The DMA will load the chain descriptor from the address assigned by HWFRQoSAR.</p> <p>SW must check RXQo_DMA_STATUS is inactive before start.</p> <p>Writing 0 does nothing. Read always returns 0.</p>                                                                                                                                                                                                                                                                                                              |
| 16     | RXQo_DMA_STOP      | <p><b>Stop the RXo queue DMA operation, the content in the RXQo FIFO and RXQo length FIFO will be cleared.</b></p> <p>Firmware writes 1 to stop the DMA. Writing 0 does nothing.</p> <p>Read returns current RXQo operation state (1: stop operation is ongoing, 0: stop operation is finished).</p> <p><b>When write:</b></p> <p>To indicate HIF that 1 RX packet in this packet length is queued into this RX queue.</p> <p><b>When read:</b></p> <p>Read the 1st RX packet length indicated from this queue, and will be 0 when queue is empty.</p>                                                 |
| 15:0   | RXQo_PACKET_LENGTH | <p>FW will write this FIFO-like port (at most 64 entries depends on the hardware configuration for each project) together with RXQ1_DMA_RUM bit been set, after RX packet is queued into descriptor chain.</p> <p>RX packet with length been set by this field is able to be read by host driver, which is through reading WRPLR, or INT enhance mode, or RX enhance mode.</p> <p>None-empty entry will generate RX done interrupt, and corresponding entry will be cleared by HW after this packet length is read by host driver.</p> <p>Writing 0 does nothing.</p> <p>0: inactive<br/>1: active</p> |

| A10401C4 HWRQ1CR |                   | HIF WLAN RX Queue 1 Control Register |    |    |    |    |    |    |    |    |    |    |                                           |                                           |                                      |                                     | oooooooooooo |   |   |  |
|------------------|-------------------|--------------------------------------|----|----|----|----|----|----|----|----|----|----|-------------------------------------------|-------------------------------------------|--------------------------------------|-------------------------------------|--------------|---|---|--|
| Bit              | 31                | 30                                   | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19                                        | 18                                        | 17                                   | 16                                  |              |   |   |  |
| Name             |                   |                                      |    |    |    |    |    |    |    |    |    |    | RX<br>Q1<br>D<br>MA<br>S<br>TA<br>TU<br>S | RX<br>Q1<br>D<br>MA<br>S<br>TA<br>R<br>UM | RX<br>Q1<br>D<br>MA<br>S<br>TA<br>RT | RX<br>Q1<br>D<br>MA<br>S<br>TO<br>P |              |   |   |  |
| Type             |                   |                                      |    |    |    |    |    |    |    |    |    |    | RO                                        | W1S                                       | W1S                                  | W1S                                 |              |   |   |  |
| Reset            |                   |                                      |    |    |    |    |    |    |    |    |    |    | 0                                         | 0                                         | 0                                    | 0                                   |              |   |   |  |
| Bit              | 15                | 14                                   | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3                                         | 2                                         | 1                                    | 0                                   |              |   |   |  |
| Name             | RX1_PACKET_LENGTH |                                      |    |    |    |    |    |    |    |    |    |    |                                           |                                           |                                      |                                     |              |   |   |  |
| Type             | RW                |                                      |    |    |    |    |    |    |    |    |    |    |                                           |                                           |                                      |                                     |              |   |   |  |
| Reset            | 0                 | 0                                    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                                         | 0                                         | 0                                    | 0                                   | 0            | 0 | 0 |  |

| Bit(s) | Name            | Description                                                                                                                                                                                                                                                                                                           |
|--------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19     | RXQ1_DMA_STATUS | <p><b>Read for the RXQ1 DMA status.</b></p> <p>When the SDIO Controller is reset, the queue is in the inactive state by default. After receiving a START or RESUME command and executing it without error, the queue enters the active state. When the queue is empty or stopped by a STOP command, it returns to</p> |

| Bit(s) | Name              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18     | RXQ1_DMA_RUM      | the inactive state.<br>0: inactive<br>1: active<br><b>Resume the RX1 queue DMA to operate.</b><br>The DMA will reload the chain descriptor from the current address. Firmware writes 1 to enable the DMA. Writing 0 does nothing. Read always returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 17     | RXQ1_DMA_START    | <b>Start the RX1 queue DMA operation.</b><br>The DMA will load the chain descriptor from the address assigned by HWFRQ1SAR. SW must check RXQ1_DMA_STATUS is inactive before start. Writing 0 does nothing. Read always returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 16     | RXQ1_DMA_STOP     | <b>Stop the RX1 queue DMA operation, the content in the RXQ1 FIFO and RXQ1 length FIFO will be cleared.</b><br>Firmware writes 1 to stop the DMA. Writing 0 does nothing. Read returns current RXQ1 operation state (1: active, 0: stopped).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 15:0   | RX1_PACKET_LENGTH | <b>When write:</b><br>To indicate HIF that 1 RX packet in this packet length is queued into this RX queue.<br><b>When read:</b><br>Read the 1st RX packet length indicated from this queue, and will be 0 when queue is empty.<br><br>FW will write this FIFO-like port (at most 64 entries depends on the hardware configuration for each project) together with RXQ1_DMA_RUM bit been set, after RX packet is queued into descriptor chain.<br>RX packet with length been set by this field is able to be read by host driver, which is through reading WRPLR, or INT enhance mode, or RX enhance mode.<br>None-empty entry will generate RX done interrupt, and corresponding entry will be cleared by HW after this packet length is read by host driver.<br>Writing 0 does nothing. |

| A10401C8 <u>HWRQ2CR</u> |                   | HIF WLAN RX Queue 2 Control Register |    |    |    |    |    |    |    |    |    |    |                                           |                                           |                                      | oooooooo                            |   |  |  |
|-------------------------|-------------------|--------------------------------------|----|----|----|----|----|----|----|----|----|----|-------------------------------------------|-------------------------------------------|--------------------------------------|-------------------------------------|---|--|--|
| Bit                     | 31                | 30                                   | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19                                        | 18                                        | 17                                   | 16                                  |   |  |  |
| Name                    |                   |                                      |    |    |    |    |    |    |    |    |    |    | RX<br>Q2<br>D<br>MA<br>S<br>TA<br>TU<br>S | RX<br>Q2<br>D<br>MA<br>S<br>TA<br>R<br>UM | RX<br>Q2<br>D<br>MA<br>S<br>TA<br>RT | RX<br>Q2<br>D<br>MA<br>S<br>TO<br>P |   |  |  |
| Type                    |                   |                                      |    |    |    |    |    |    |    |    |    |    | RO                                        | W1S                                       | W1S                                  | W1S                                 |   |  |  |
| Reset                   |                   |                                      |    |    |    |    |    |    |    |    |    |    | 0                                         | 0                                         | 0                                    | 0                                   |   |  |  |
| Bit                     | 15                | 14                                   | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3                                         | 2                                         | 1                                    | 0                                   |   |  |  |
| Name                    | RX2_PACKET_LENGTH |                                      |    |    |    |    |    |    |    |    |    |    |                                           |                                           |                                      |                                     |   |  |  |
| Type                    | RW                |                                      |    |    |    |    |    |    |    |    |    |    |                                           |                                           |                                      |                                     |   |  |  |
| Reset                   | 0                 | 0                                    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                                         | 0                                         | 0                                    | 0                                   | 0 |  |  |

| Bit(s) | Name            | Description                                                                                                   |
|--------|-----------------|---------------------------------------------------------------------------------------------------------------|
| 19     | RXQ2_DMA_STATUS | <b>Read for the RXQ2 DMA status.</b><br>When the SDIO Controller is reset, the queue is in the inactive state |

| Bit(s) | Name              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18     | RXQ2_DMA_RUM      | by default. After receiving a START or RESUME command and executing it without error, the queue enters the active state. When the queue is empty or stopped by a STOP command, it returns to the inactive state.<br>0: inactive<br>1: active                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 17     | RXQ2_DMA_START    | <b>Resume the RX2 queue DMA to operate.</b><br>The DMA will reload the chain descriptor from the current address. Firmware writes 1 to enable the DMA. Writing 0 does nothing. Read always returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 16     | RXQ2_DMA_STOP     | <b>Start the RX2 queue DMA operation.</b><br>The DMA will load the chain descriptor from the address assigned by HWFRQ1SAR.<br>SW must check RXQ2_DMA_STATUS is inactive before start.<br>Writing 0 does nothing. Read always returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 15:0   | RX2_PACKET_LENGTH | <b>Stop the RX2 queue DMA operation, the content in the RXQ2 FIFO and RXQ2 length FIFO will be cleared.</b><br>Firmware writes 1 to stop the DMA. Writing 0 does nothing.<br>Read returns current RXQ2 operation state (1: active, 0: stopped).<br><b>When write:</b><br>To indicate HIF that 1 RX packet in this packet length is queued into this RX queue.<br><b>When read:</b><br>Read the 1st RX packet length indicated from this queue, and will be 0 when queue is empty.<br><br>FW will write this FIFO-like port (at most 64 entries depends on the hardware configuration for each project) together with RXQ2_DMA_RUM bit been set, after RX packet is queued into descriptor chain.<br>RX packet with length been set by this field is able to be read by host driver, which is through reading WRPLR, or INT enhance mode, or RX enhance mode.<br>None-empty entry will generate RX done interrupt, and corresponding entry will be cleared by HW after this packet length is read by host driver.<br>Writing 0 does nothing. |

**A10401CC HWRQ3CR****HIF WLAN RX Queue 3 Control Register****oooooooo**

| Bit          | 31                | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19        | 18        | 17        | 16        |
|--------------|-------------------|----|----|----|----|----|----|----|----|----|----|----|-----------|-----------|-----------|-----------|
| <b>Name</b>  |                   |    |    |    |    |    |    |    |    |    |    |    | <b>RX</b> | <b>RX</b> | <b>RX</b> | <b>RX</b> |
|              |                   |    |    |    |    |    |    |    |    |    |    |    | <b>Q3</b> | <b>Q3</b> | <b>Q3</b> | <b>Q3</b> |
|              |                   |    |    |    |    |    |    |    |    |    |    |    | <b>_D</b> | <b>_D</b> | <b>_D</b> | <b>_D</b> |
|              |                   |    |    |    |    |    |    |    |    |    |    |    | <b>MA</b> | <b>MA</b> | <b>MA</b> | <b>MA</b> |
|              |                   |    |    |    |    |    |    |    |    |    |    |    | <b>_S</b> | <b>_S</b> | <b>_S</b> | <b>_S</b> |
|              |                   |    |    |    |    |    |    |    |    |    |    |    | <b>TA</b> | <b>TA</b> | <b>TA</b> | <b>TO</b> |
|              |                   |    |    |    |    |    |    |    |    |    |    |    | <b>TU</b> | <b>UM</b> | <b>RT</b> | <b>P</b>  |
| <b>Type</b>  |                   |    |    |    |    |    |    |    |    |    |    |    | RO        | W1S       | W1S       | W1S       |
| <b>Reset</b> |                   |    |    |    |    |    |    |    |    |    |    |    | 0         | 0         | 0         | 0         |
| Bit          | 15                | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3         | 2         | 1         | 0         |
| <b>Name</b>  | RX3_PACKET_LENGTH |    |    |    |    |    |    |    |    |    |    |    |           |           |           |           |
| <b>Type</b>  | RW                |    |    |    |    |    |    |    |    |    |    |    |           |           |           |           |
| <b>Reset</b> | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0         | 0         | 0         |           |

| Bit(s) | Name              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19     | RXQ3_DMA_STATUS   | <p><b>Read for the RXQ3 DMA status.</b><br/>When the SDIO Controller is reset, the queue is in the inactive state by default. After receiving a START or RESUME command and executing it without error, the queue enters the active state. When the queue is empty or stopped by a STOP command, it returns to the inactive state.<br/>0: inactive<br/>1: active</p>                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 18     | RXQ3_DMA_RUM      | <p><b>Resume the RX3 queue DMA to operate.</b><br/>The DMA will reload the chain descriptor from the current address. Firmware writes 1 to enable the DMA. Writing 0 does nothing. Read always returns 0.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 17     | RXQ3_DMA_START    | <p><b>Start the RX3 queue DMA operation.</b><br/>The DMA will load the chain descriptor from the address assigned by HWFRQ1SAR.<br/>SW must check RXQ3_DMA_STATUS is inactive before start. Writing 0 does nothing. Read always returns 0.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 16     | RXQ3_DMA_STOP     | <p><b>Stop the RX3 queue DMA operation, the content in the RXQ3 FIFO and RXQ3 length FIFO will be cleared.</b><br/>Firmware writes 1 to stop the DMA. Writing 0 does nothing. Read returns current RXQ3 operation state (1: active, 0: stopped).</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 15:0   | RX3_PACKET_LENGTH | <p><b>When write:</b><br/>To indicate HIF that 1 RX packet in this packet length is queued into this RX queue.<br/><b>When read:</b><br/>Read the 1st RX packet length indicated from this queue, and will be 0 when queue is empty.</p> <p>FW will write this FIFO-like port (at most 64 entries depends on the hardware configuration for each project) together with RXQ3_DMA_RUM bit been set, after RX packet is queued into descriptor chain.<br/>RX packet with length been set by this field is able to be read by host driver, which is through reading WRPLR, or INT enhance mode, or RX enhance mode.<br/>None-empty entry will generate RX done interrupt, and corresponding entry will be cleared by HW after this packet length is read by host driver.<br/>Writing 0 does nothing.</p> |

| A10401Do HWRQ4CR |                  | Reserve for HWRQ4CR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |  |
|------------------|------------------|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--|
| Bit              | 31               | 30                  | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |  |
| Name             | RESV_FOR_HWRQ4CR |                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |  |
| Type             | RW               |                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |  |
| Reset            | 0                | 0                   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |  |
| Bit              | 15               | 14                  | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |  |
| Name             | RESV_FOR_HWRQ4CR |                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |  |
| Type             | RW               |                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |  |
| Reset            | 0                | 0                   | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |  |

| Bit(s) | Name             | Description      |
|--------|------------------|------------------|
| 31:0   | RESV_FOR_HWRQ4CR | RESV_FOR_HWRQ4CR |

**A10401D4 HWRQ5CR****Reserve for HWRQ5CR****oooooooooo**

| Bit   | 31               | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | RESV_FOR_HWRQ5CR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15               | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | RESV_FOR_HWRQ5CR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**Bit(s)****Name****Description**

31:0 RESV\_FOR\_HWRQ5CR

**A10401D8 HWRQ6CR****Reserve for HWRQ6CR****oooooooooo**

| Bit   | 31               | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | RESV_FOR_HWRQ6CR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15               | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | RESV_FOR_HWRQ6CR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**Bit(s)****Name****Description**

31:0 RESV\_FOR\_HWRQ6CR

**A10401DC HWRQ7CR****Reserve for HWRQ7CR****oooooooooo**

| Bit   | 31               | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | RESV_FOR_HWRQ7CR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15               | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | RESV_FOR_HWRQ7CR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**Bit(s)****Name****Description**

31:0 RESV\_FOR\_HWRQ7CR

**A10401E0 HWRLFACR****HIF WLAN RX Length FIFO Available****40404040**

## Count Register

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    | 1  | 0  | 0  | 0  | 0  | 0  | 0  |    | 1  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    | 1  | 0  | 0  | 0  | 0  | 0  | 0  |    | 1  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name                   | Description                                                                                                                                                                                                                                                                                                                |
|--------|------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 30:24  | RX3_LEN_FIFO_AVAIL_CNT | <b>It indicates the RX3 length FIFO available count. SW should prevent push extra entries into FIFO.</b><br>If under the define of SDCTL_RX3_PACKET_LEN_64, The maximum is 64.<br>If under the define of SDCTL_RX3_PACKET_LEN_32, The maximum is 32.<br>If under the define of SDCTL_RX3_PACKET_LEN_16, The maximum is 16. |
| 22:16  | RX2_LEN_FIFO_AVAIL_CNT | <b>It indicates the RX2 length FIFO available count. SW should prevent push extra entries into FIFO.</b><br>If under the define of SDCTL_RX2_PACKET_LEN_64, The maximum is 64.<br>If under the define of SDCTL_RX2_PACKET_LEN_32, The maximum is 32.<br>If under the define of SDCTL_RX2_PACKET_LEN_16, The maximum is 16. |
| 14:8   | RX1_LEN_FIFO_AVAIL_CNT | <b>It indicates the RX1 length FIFO available count. SW should prevent push extra entries into FIFO.</b><br>If under the define of SDCTL_RXD_PACKET_LEN_64, The maximum is 64.<br>If under the define of SDCTL_RXD_PACKET_LEN_32, The maximum is 32.<br>If under the define of SDCTL_RXD_PACKET_LEN_16, The maximum is 16. |
| 6:0    | RXo_LEN_FIFO_AVAIL_CNT | <b>It indicates the RXo length FIFO available count. SW should prevent push extra entries into FIFO.</b><br>If under the define of SDCTL_RXE_PACKET_LEN_64, The maximum is 64.<br>If under the define of SDCTL_RXE_PACKET_LEN_32, The maximum is 32.<br>If under the define of SDCTL_RXE_PACKET_LEN_16, The maximum is 16. |

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Type   | RO |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|--------|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Rese t | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| Bit(s) | Name               | Description        |
|--------|--------------------|--------------------|
| 31:0   | RESV_FOR_HWRLFACR1 | RESV_FOR_HWRLFACR1 |

| <b>A10401E8 HWDMACR</b> <b>HIF WLAN DMA Control Register</b> <b>0000004A</b> |    |    |    |    |    |    |    |    |               |                |           |        |          |          |    |    |
|------------------------------------------------------------------------------|----|----|----|----|----|----|----|----|---------------|----------------|-----------|--------|----------|----------|----|----|
| Bit                                                                          | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23            | 22             | 21        | 20     | 19       | 18       | 17 | 16 |
| Name                                                                         |    |    |    |    |    |    |    |    |               |                |           |        |          |          |    |    |
| Type                                                                         |    |    |    |    |    |    |    |    |               |                |           |        |          |          |    |    |
| Rese t                                                                       |    |    |    |    |    |    |    |    |               |                |           |        |          |          |    |    |
| Bit                                                                          | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7             | 6              | 5         | 4      | 3        | 2        | 1  | 0  |
| Name                                                                         |    |    |    |    |    |    |    |    | DMA_BS T_SIZE | AHB_PR OT2_CTL | AR BIT ER | M OD E | DE ST _B | AH KB _P |    |    |
| Type                                                                         |    |    |    |    |    |    |    |    | RW            | RW             | RW        | RW     | RW       | RW       | RW | RW |
| Rese t                                                                       |    |    |    |    |    |    |    |    | 0             | 1              | 0         | 0      | 1        | 1        | 0  |    |

| Bit(s) | Name          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:6    | DMA_BST_SIZE  | <b>This field is used to determine the DMA burst size</b><br>0 : burst size = 4 DW<br>1: burst size = 8 DW<br>2: burst_size = 16DW                                                                                                                                                                                                                                                                                                                                                                                                          |
| 5:4    | AHB_PROT2_CTL | <b>This field is used to Control AHB bus Protection 2 function</b><br>00: DMA engine would use HPROT[2] signal on AHB bus to be 0 to protect HWO write back. This is used to guarantee that MCU would receive interrupt after the HWO is written. For other data writes, HPROT[2] is set to 1 to indicate that it is Bufferable<br>01: The HPROT[2] signal on AHB bus is always set to 0, which means all AHB writes are not Bufferable<br>10: The HPROT[2] signal on AHB bus is always set to 1, which means all AHB writes are Bufferable |
| 3      | ARBITER_MODE  | <b>For Normal Mode, the arbitration algorithm is more preference for TX direction (from HOST to FW), which is good for reducing the duration time during write busy in SDIO interface.</b><br>And for the Reserve Mode, it is more aggressive than the Normal Mode which means RX will not be executed unless the TX has been completed.<br>0: Reserve Mode<br>1: Normal Mode (Recommend)                                                                                                                                                   |
| 1      | DEST_BST_TYP  | <b>This field is used to specify the AHB burst type for HWO write back.</b><br>0: HIFSYS DMA engine would use non-post-write (INCR, burst type = 3'b001) to write 0 to HWO when the responding data is dealt. This access could guarantee that MCU would receive interrupt after the HWO is written.<br>1: HIFSYS DMA engine would use post-write (SINGLE, burst type = 3'booo) to write 0 to HWO when the responding data is dealt. This                                                                                                   |

| Bit(s) | Name              | Description                                                                                                                                                                                                                                                                                                                          |
|--------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | AHB_1KBNDRY_PRTCT | <p>access could NOT guarantee that MCU would receive interrupt after the HWO is written.</p> <p><b>This field is used to specify whether to protect the 1K boundary or not</b></p> <ul style="list-style-type: none"> <li>o: Don't protect.</li> <li>1: DMA will guarantee the AHB will not cross 1K boundary in a burst.</li> </ul> |

**A10401EC HWFIOCDR****HIF WLAN Firmware GPD IOC bit  
Disable Register**

00000FFF

| Bit           | 31 | 30 | 29 | 28 | 27                          | 26                          | 25                          | 24                          | 23                          | 22                          | 21                          | 20                          | 19                          | 18                          | 17                          | 16                          |  |  |
|---------------|----|----|----|----|-----------------------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|--|--|
| <b>Name</b>   |    |    |    |    |                             |                             |                             |                             |                             |                             |                             |                             |                             |                             |                             |                             |  |  |
| <b>Type</b>   |    |    |    |    |                             |                             |                             |                             |                             |                             |                             |                             |                             |                             |                             |                             |  |  |
| <b>Rese t</b> |    |    |    |    |                             |                             |                             |                             |                             |                             |                             |                             |                             |                             |                             |                             |  |  |
| Bit           | 15 | 14 | 13 | 12 | 11                          | 10                          | 9                           | 8                           | 7                           | 6                           | 5                           | 4                           | 3                           | 2                           | 1                           | 0                           |  |  |
| <b>Name</b>   |    |    |    |    | RX<br>Q3<br>_IO<br>C<br>DIS | RX<br>Q2<br>_IO<br>C<br>DIS | RX<br>Q1<br>_IO<br>C<br>DIS | RX<br>Q0<br>_IO<br>C<br>DIS | TX<br>Q7<br>_IO<br>C<br>DIS | TX<br>Q6<br>_IO<br>C<br>DIS | TX<br>Q5<br>_IO<br>C<br>DIS | TX<br>Q4<br>_IO<br>C<br>DIS | TX<br>Q3<br>_IO<br>C<br>DIS | TX<br>Q2<br>_IO<br>C<br>DIS | TX<br>Q1<br>_IO<br>C<br>DIS | TX<br>Q0<br>_IO<br>C<br>DIS |  |  |
| <b>Type</b>   |    |    |    |    | RW                          |  |  |
| <b>Rese t</b> |    |    |    |    | 1                           | 1                           | 1                           | 1                           | 1                           | 1                           | 1                           | 1                           | 1                           | 1                           | 1                           | 1                           |  |  |

| Bit(s) | Name         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11     | RXQ3_IOC_DIS | <p>If firmware write 1 to this register, the corresponding queue always issue interrupt event when GPD is done.</p> <p>If firmware write 0 to this register, the corresponding queue will issue interrupt event base on GPD IOC bit. If current GPD IOC = 1, GPD done interrupt event will be issued and latched into HWFRE1SR.</p> <ul style="list-style-type: none"> <li>o: Enable IOC function.</li> <li>1: Disable IOC function (always issue interrupt when GPD done)</li> </ul> |
| 10     | RXQ2_IOC_DIS | <p>If firmware write 1 to this register, the corresponding queue always issue interrupt event when GPD is done.</p> <p>If firmware write 0 to this register, the corresponding queue will issue interrupt event base on GPD IOC bit. If current GPD IOC = 1, GPD done interrupt event will be issued and latched into HWFRE1SR.</p> <ul style="list-style-type: none"> <li>o: Enable IOC function.</li> <li>1: Disable IOC function (always issue interrupt when GPD done)</li> </ul> |
| 9      | RXQ1_IOC_DIS | <p>If firmware write 1 to this register, the corresponding queue always issue interrupt event when GPD is done.</p> <p>If firmware write 0 to this register, the corresponding queue will issue interrupt event base on GPD IOC bit. If current GPD IOC = 1, GPD done interrupt event will be issued and latched into HWFRE1SR.</p> <ul style="list-style-type: none"> <li>o: Enable IOC function.</li> <li>1: Disable IOC function (always issue interrupt when GPD done)</li> </ul> |
| 8      | RXQ0_IOC_DIS | <p>If firmware write 1 to this register, the corresponding queue always issue interrupt event when GPD is done.</p> <p>If firmware write 0 to this register, the corresponding queue will issue interrupt event base on GPD IOC bit. If current GPD IOC = 1, GPD done interrupt event will be issued and latched into HWFRE1SR.</p> <ul style="list-style-type: none"> <li>o: Enable IOC function.</li> <li>1: Disable IOC function (always issue interrupt when GPD done)</li> </ul> |

| Bit(s) | Name         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7      | TXQ7_IOC_DIS | <p>1: Disable IOC function (always issue interrupt when GPD done)<br/> <b>If firmware write 1 to this register, the corresponding queue always issue interrupt event when GPD is done.</b><br/>         If firmware write 0 to this register, the corresponding queue will issue interrupt event base on GPD IOC bit. If current GPD IOC = 1, GPD done interrupt event will be issued and latched into HWFTEoSR.</p> <p>0: Enable IOC function.</p> |
| 6      | TXQ6_IOC_DIS | <p>1: Disable IOC function (always issue interrupt when GPD done)<br/> <b>If firmware write 1 to this register, the corresponding queue always issue interrupt event when GPD is done.</b><br/>         If firmware write 0 to this register, the corresponding queue will issue interrupt event base on GPD IOC bit. If current GPD IOC = 1, GPD done interrupt event will be issued and latched into HWFTEoSR.</p> <p>0: Enable IOC function.</p> |
| 5      | TXQ5_IOC_DIS | <p>1: Disable IOC function (always issue interrupt when GPD done)<br/> <b>If firmware write 1 to this register, the corresponding queue always issue interrupt event when GPD is done.</b><br/>         If firmware write 0 to this register, the corresponding queue will issue interrupt event base on GPD IOC bit. If current GPD IOC = 1, GPD done interrupt event will be issued and latched into HWFTEoSR.</p> <p>0: Enable IOC function.</p> |
| 4      | TXQ4_IOC_DIS | <p>1: Disable IOC function (always issue interrupt when GPD done)<br/> <b>If firmware write 1 to this register, the corresponding queue always issue interrupt event when GPD is done.</b><br/>         If firmware write 0 to this register, the corresponding queue will issue interrupt event base on GPD IOC bit. If current GPD IOC = 1, GPD done interrupt event will be issued and latched into HWFTEoSR.</p> <p>0: Enable IOC function.</p> |
| 3      | TXQ3_IOC_DIS | <p>1: Disable IOC function (always issue interrupt when GPD done)<br/> <b>If firmware write 1 to this register, the corresponding queue always issue interrupt event when GPD is done.</b><br/>         If firmware write 0 to this register, the corresponding queue will issue interrupt event base on GPD IOC bit. If current GPD IOC = 1, GPD done interrupt event will be issued and latched into HWFTEoSR.</p> <p>0: Enable IOC function.</p> |
| 2      | TXQ2_IOC_DIS | <p>1: Disable IOC function (always issue interrupt when GPD done)<br/> <b>If firmware write 1 to this register, the corresponding queue always issue interrupt event when GPD is done.</b><br/>         If firmware write 0 to this register, the corresponding queue will issue interrupt event base on GPD IOC bit. If current GPD IOC = 1, GPD done interrupt event will be issued and latched into HWFTEoSR.</p> <p>0: Enable IOC function.</p> |
| 1      | TXQ1_IOC_DIS | <p>1: Disable IOC function (always issue interrupt when GPD done)<br/> <b>If firmware write 1 to this register, the corresponding queue always issue interrupt event when GPD is done.</b><br/>         If firmware write 0 to this register, the corresponding queue will issue interrupt event base on GPD IOC bit. If current GPD IOC = 1, GPD done interrupt event will be issued and latched into HWFTEoSR.</p> <p>0: Enable IOC function.</p> |
| 0      | TXQ0_IOC_DIS | <p>1: Disable IOC function (always issue interrupt when GPD done)<br/> <b>If firmware write 1 to this register, the corresponding queue always issue interrupt event when GPD is done.</b><br/>         If firmware write 0 to this register, the corresponding queue will</p>                                                                                                                                                                      |

| Bit(s) | Name | Description                                                                                                                                                                                                                        |
|--------|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |      | issue interrupt event base on GPD IOC bit. If current GPD IOC = 1, GPD done interrupt event will be issued and latched into HWFTEosR.<br>0: Enable IOC function.<br>1: Disable IOC function (always issue interrupt when GPD done) |

| <b>A10401Fo HSDIOTOCR</b> |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>HIF SDIO Time-Out Control Register</b> |    |    |    | <b>00032000</b> |    |    |
|---------------------------|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------------------------------|----|----|----|-----------------|----|----|
| Bit                       | 31              | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                                        | RE | RE | G_ | RD              | TI | TI |
| Name                      |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    | WR                                        | RD | ME | ME | OU              | T_ |    |
| Type                      |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    | EN                                        | EN | TI | ME | OU              | T_ |    |
| Bit                       | 15              | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                                         | RW | RW |    |                 |    |    |
| Name                      | REG_TIMEOUT_NUM |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                           |    |    |    |                 |    |    |
| Type                      | RW              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                           |    |    |    |                 |    |    |
| Reset                     | 0               | 0  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                                         | 0  | 0  | 0  | 0               | 0  |    |

| Bit(s) | Name              | Description                                                                                                                                                                            |
|--------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17     | REG_WR_TIMEOUT_EN | Firmware can write 0 to this field to disable SDIO write timeout function and write 1 to enable the function.<br>0: Disable SDIO timeout function.<br>1: Enable SDIO timeout function. |
| 16     | REG_RD_TIMEOUT_EN | Firmware can write 0 to this field to disable SDIO read timeout function and write 1 to enable the function.<br>0: Disable SDIO timeout function.<br>1: Enable SDIO timeout function.  |
| 15:0   | REG_TIMEOUT_NUM   | Firmware can write this field to decide the timeout threshold. The unit is SDIO clock cycle number.                                                                                    |

| <b>A1040200 HWFTSRO</b> |         |    |    |    |    |    |    |    |         |    |    |    |    |    |    | <b>HIF WLAN Firmware TX Status Register 0</b> |   |   |   | <b>00000000</b> |   |   |
|-------------------------|---------|----|----|----|----|----|----|----|---------|----|----|----|----|----|----|-----------------------------------------------|---|---|---|-----------------|---|---|
| Bit                     | 31      | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16                                            |   |   |   |                 |   |   |
| Name                    | TQ3_CNT |    |    |    |    |    |    |    | TQ2_CNT |    |    |    |    |    |    |                                               |   |   |   |                 |   |   |
| Type                    | RO      |    |    |    |    |    |    |    | RO      |    |    |    |    |    |    |                                               |   |   |   |                 |   |   |
| Reset                   | 0       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0       | 0  | 0  | 0  | 0  | 0  | 0  | 0                                             | 0 | 0 | 0 | 0               | 0 | 0 |
| Bit                     | 15      | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7       | 6  | 5  | 4  | 3  | 2  | 1  | 0                                             |   |   |   |                 |   |   |
| Name                    | TQ1_CNT |    |    |    |    |    |    |    | TQo_CNT |    |    |    |    |    |    |                                               |   |   |   |                 |   |   |
| Type                    | RO      |    |    |    |    |    |    |    | RO      |    |    |    |    |    |    |                                               |   |   |   |                 |   |   |
| Reset                   | 0       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0       | 0  | 0  | 0  | 0  | 0  | 0  | 0                                             | 0 | 0 | 0 | 0               | 0 | 0 |

| Bit(s) | Name    | Description                                             |
|--------|---------|---------------------------------------------------------|
| 31:24  | TQ3_CNT | Firmware can read this field to know the accumulated TX |

| Bit(s) | Name    | Description                                                                                                                     |
|--------|---------|---------------------------------------------------------------------------------------------------------------------------------|
| 23:16  | TQ2_CNT | queue count in SDIO controller which are still not read by host driver.                                                         |
| 15:8   | TQ1_CNT | Firmware can read this field to know the accumulated TX queue count in SDIO controller which are still not read by host driver. |
| 7:0    | TQ0_CNT | Firmware can read this field to know the accumulated TX queue count in SDIO controller which are still not read by host driver. |

**A1040204 HWFTSR1** HIF WLAN Firmware TX Status Register 1 **oooooooooooo**

| Bit          | 31      | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|---------|----|----|----|----|----|----|----|---------|----|----|----|----|----|----|----|
| <b>Name</b>  | TQ7_CNT |    |    |    |    |    |    |    | TQ6_CNT |    |    |    |    |    |    |    |
| <b>Type</b>  | RO      |    |    |    |    |    |    |    | RO      |    |    |    |    |    |    |    |
| <b>Reset</b> | 0       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0       | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>   | 15      | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7       | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | TQ5_CNT |    |    |    |    |    |    |    | TQ4_CNT |    |    |    |    |    |    |    |
| <b>Type</b>  | RO      |    |    |    |    |    |    |    | RO      |    |    |    |    |    |    |    |
| <b>Reset</b> | 0       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0       | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name    | Description                                                                                                                     |
|--------|---------|---------------------------------------------------------------------------------------------------------------------------------|
| 31:24  | TQ7_CNT | Firmware can read this field to know the accumulated TX queue count in SDIO controller which are still not read by host driver. |
| 23:16  | TQ6_CNT | Firmware can read this field to know the accumulated TX queue count in SDIO controller which are still not read by host driver. |
| 15:8   | TQ5_CNT | Firmware can read this field to know the accumulated TX queue count in SDIO controller which are still not read by host driver. |
| 7:0    | TQ4_CNT | Firmware can read this field to know the accumulated TX queue count in SDIO controller which are still not read by host driver. |

| Bit          | 31                | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23                | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|-------------------|----|----|----|----|----|----|----|-------------------|----|----|----|----|----|----|----|
| <b>Name</b>  | TX_1.RE_CO_RD_E_N |    |    |    |    |    |    |    | RX_1.RE_CO_RD_E_N |    |    |    |    |    |    |    |
| <b>Type</b>  | RW                |    |    |    |    |    |    |    | RW                |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                 |    |    |    |    |    |    |    | 0                 |    |    |    |    |    |    |    |
| <b>Bit</b>   | 15                | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7                 | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | DBG_PKTLEN_OFFSET |    |    |    |    |    |    |    |                   |    |    |    |    |    |    |    |

| Type  | RW |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |
|-------|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Reset | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| Bit(s) | Name              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19     | TX1_RECORD_EN     | Firmware can write 1 to this field to enable TX1 data port record in debug mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 18     | RX1_RECORD_EN     | Firmware can write 1 to this field to enable RX1 data port record in debug mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 17     | RXo_RECORD_EN     | Firmware can write 1 to this field to enable RXo data port record in debug mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 16     | NO_DMU_DBG_MODE   | Firmware can write 1 to this field to enable the virtual direct DMA debug mode. When this mode is enabled, the data transfer between SDIO controller and SDIO wrapper would also be written to SDIO internal memory in PIO mode for debug use. Firmware can enable the data port to be recorded by writing 1 to the corresponding field in this register. Only one data port should be recorded each single time for the debug mode so that the record condition can be applied to that port correctly. The record condition would be packet size and packet length offset. Packets that meet both two criteria would be recorded. |
| 15:0   | DBG_PKTLEN_OFFSET | Since the memory used for debug is only roughly 2KB and might not be enough to record one full packet size, firmware can set this field to indicate the offset of one packet size to be recorded. This field is limited to be DW alignment size. E.g. firmware writes 20 to this field meaning that the data from byte 21 would be recorded.                                                                                                                                                                                                                                                                                       |

**A1040214 HWDBGPLR** HIF WLAN Debug Packet Length Register **oooooooooooo**

| Bit   | 31                | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|-------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | DBG_LEN_UP_BOUND  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15                | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | DBG_LEN_LOW_BOUND |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name              | Description                                                                                                                                                 |
|--------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16  | DBG_LEN_UP_BOUND  | Firmware can write this field to decide the upper bound packet size to record. Packets that meet both the upper and lower bound criteria would be recorded. |
| 15:0   | DBG_LEN_LOW_BOUND | Firmware can write this field to decide the lower bound packet size to record. Packets that meet both the upper and lower bound criteria would be recorded. |

**A1040218 HSPICSR** WLAN SPI Control Status Register (SPI **oooooooooooo** Only)

| Bit  | 31 | 30 | 29 | 28 | 27              | 26              | 25              | 24              | 23 | 22 | 21 | 20              | 19              | 18                    | 17              | 16 |
|------|----|----|----|----|-----------------|-----------------|-----------------|-----------------|----|----|----|-----------------|-----------------|-----------------------|-----------------|----|
| Name |    |    |    |    | D <sub>CP</sub> | D <sub>CP</sub> | D <sub>MO</sub> | D <sub>EN</sub> |    |    |    | D <sub>CP</sub> | D <sub>CP</sub> | D <sub>BIT_MODE</sub> | D <sub>EN</sub> |    |

|        | <u>OL</u>        | <u>HA</u>        | <u>DE</u>        | <u>DI</u>        |    |    |    | <u>OL</u> | <u>HA</u>        |                  | <u>DI</u>            | <u>AN</u>               |
|--------|------------------|------------------|------------------|------------------|----|----|----|-----------|------------------|------------------|----------------------|-------------------------|
| Type   |                  |                  |                  |                  |    |    |    |           |                  |                  |                      |                         |
| Rese t | 0                | 0                | 0                | 0                |    |    |    | 0         | 0                | 0                | 0                    | 0                       |
| Bit    | 15               | 14               | 13               | 12               | 11 | 10 | 9  | 8         | 7                | 6                | 5                    | 4                       |
| Name   | <u>CP<br/>OL</u> | <u>CP<br/>HA</u> | <u>MO<br/>DE</u> | <u>EN<br/>DI</u> |    |    |    |           | <u>CP<br/>OL</u> | <u>CP<br/>HA</u> | <u>BIT_MOD<br/>E</u> | <u>EN<br/>DI<br/>AN</u> |
| Type   |                  |                  |                  |                  | RW | RW | RW | RW        |                  |                  | RW                   | RW                      |
| Rese t | 0                | 0                | 0                | 0                |    |    |    |           | 0                | 0                | 0                    | 0                       |

| Bit(s) | Name                 | Description                                                                                       |
|--------|----------------------|---------------------------------------------------------------------------------------------------|
| 27     | D_CPOL_SET_CONTROL   | <b>[debug bit]</b><br>0: CPOL set by firmware or eFuse<br>1: CPOL set by wspicsr bit[6]           |
| 26     | D_CPHA_SET_CONTROL   | <b>[debug bit]</b><br>0: CPHA set by firmware or eFuse<br>1: CPHA set by wspicsr bit[5]           |
| 25     | D_MODE_SET_CONTROL   | <b>[debug bit]</b><br>0: BIT MODE set by firmware or eFuse<br>1: BIT MODE set by wspicsr bit[4:3] |
| 24     | D_ENDIAN_SET_CONTROL | <b>[debug bit]</b><br>0: ENDIAN set by firmware or eFuse<br>1: ENDIAN set by wspicsr bit[2]       |
| 20     | D_CPOL               | <b>[debug bit]</b><br>CPOL : the final work value                                                 |
| 19     | D_CPHA               | <b>[debug bit]</b><br>CPHA : the final work value                                                 |
| 18:17  | D_BIT_MODE           | <b>[debug bit]</b><br>BIT_MODE : the final work value                                             |
| 16     | D_ENDIAN             | <b>[debug bit]</b><br>ENDIAN : the final work value                                               |
| 11     | CPOL_SET_CONTROL     | 0: CPOL set by eFuse<br>1: CPOL set by firmware                                                   |
| 10     | CPHA_SET_CONTROL     | 0: CPHA set by eFuse<br>1: CPHA set by firmware                                                   |
| 9      | MODE_SET_CONTROL     | 0: BIT MODE set by eFuse<br>1: BIT MODE set by firmware                                           |
| 8      | ENDIAN_SET_CONTROL   | 0: ENDIAN set by eFuse<br>1: ENDIAN set by firmware                                               |
| 4      | CPOL                 | <b>CPOL need to be coordinated with bit[11]</b><br>0: set CPOL 0<br>1: set CPOL 1                 |
| 3      | CPHA                 | <b>CPHA need to be coordinated with bit[10]</b><br>0: set CPHA 0<br>1: set CPHA 1                 |

| Bit(s) | Name     | Description                                                                                                                        |
|--------|----------|------------------------------------------------------------------------------------------------------------------------------------|
| 2:1    | BIT_MODE | <b>this bit need to be coordinated with bit[9]</b><br>2b'00: 8bit mode<br>2b'01:16bit mode<br>2b'10:32bit mode<br>2b'11: 8bit mode |
| 0      | ENDIAN   | <b>this bit need to be coordinated with bit[8]</b><br>0: Little Endian<br>1: Big Endian                                            |

**A1040220 HWRXoCGPD DMA RXo Current GPD Address Register 00000000**

| Bit          | 31                       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|--------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  | <b>RXo_CURR_GPD_ADDR</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RO                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>   | 15                       | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | <b>RXo_CURR_GPD_ADDR</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RO                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name              | Description                                            |
|--------|-------------------|--------------------------------------------------------|
| 31:0   | RXo_CURR_GPD_ADDR | the address of RXo current GPD that is being processed |

**A1040224 HWRX1CGPD DMA RX1 Current GPD Address Register 00000000**

| Bit          | 31                       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|--------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  | <b>RX1_CURR_GPD_ADDR</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RO                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>   | 15                       | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | <b>RX1_CURR_GPD_ADDR</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RO                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name              | Description                                            |
|--------|-------------------|--------------------------------------------------------|
| 31:0   | RX1_CURR_GPD_ADDR | the address of RX1 current GPD that is being processed |

**A1040228 HWRX2CGPD DMA RX2 Current GPD Address Register 00000000**

| Bit         | 31                       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------------|--------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b> | <b>RX2_CURR_GPD_ADDR</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b> | RO                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit(s) | Name              | Description                                            |
|--------|-------------------|--------------------------------------------------------|
| 31:0   | RX2_CURR_GPD_ADDR | the address of RX2 current GPD that is being processed |

**A104022C HWRX3CGPD**      **DMA RX3 Current GPD Address Register**      **00000000**

| Bit(s) | Name              | Description                                            |
|--------|-------------------|--------------------------------------------------------|
| 31:0   | RX3_CURR_GPD_ADDR | the address of RX3 current GPD that is being processed |

**A1040230 HWTXoCGPD DMA TXo Current GPD Address Register 00000000**

| Bit(s) | Name              | Description                               |
|--------|-------------------|-------------------------------------------|
| 31:0   | TXo_CURR_GPD_ADDR | the address of TXo GPD that is processing |

**A1040234    HWTX1Q1CGPD           DMA TX1 Que Type 1 Current GPD           00000000**

---

|        |                      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|----------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Type   | RO                   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Rese t | 0                    | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Bit    | 15                   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name   | TX1_Q1_CURR_GPD_ADDR |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type   | RO                   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Rese t | 0                    | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| Bit(s) | Name                 | Description                                                      |
|--------|----------------------|------------------------------------------------------------------|
| 31:0   | TX1_Q1_CURR_GPD_ADDR | the address of TX1 channel and que type 1 GPD that is processing |

**A1040238 HWTX1Q2CGPD DMA TX1 Que Type 2 Current GPD Address Register 00000000**

|        |                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|--------|----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit    | 31                   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name   | TX1_Q2_CURR_GPD_ADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type   | RO                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t | 0                    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit    | 15                   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name   | TX1_Q2_CURR_GPD_ADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type   | RO                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t | 0                    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name                 | Description                                                      |
|--------|----------------------|------------------------------------------------------------------|
| 31:0   | TX1_Q2_CURR_GPD_ADDR | the address of TX1 channel and que type 2 GPD that is processing |

**A104023C HWTX1Q3CGPD DMA TX1 Que Type 3 Current GPD Address Register 00000000**

|        |                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|--------|----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit    | 31                   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name   | TX1_Q3_CURR_GPD_ADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type   | RO                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t | 0                    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit    | 15                   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name   | TX1_Q3_CURR_GPD_ADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type   | RO                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t | 0                    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name                 | Description                                                      |
|--------|----------------------|------------------------------------------------------------------|
| 31:0   | TX1_Q3_CURR_GPD_ADDR | the address of TX1 channel and que type 3 GPD that is processing |

**A1040240 HWTX1Q4CGPD DMA TX1 Que Type 4 Current GPD 00000000**

**Address Register**

| <b>Bit</b>   | 31                   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  | TX1_Q4_CURR_GPD_ADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RO                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>   | 15                   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | TX1_Q4_CURR_GPD_ADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RO                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| <b>Bit(s)</b> | <b>Name</b>          | <b>Description</b>                                               |
|---------------|----------------------|------------------------------------------------------------------|
| 31:0          | TX1_Q4_CURR_GPD_ADDR | the address of TX1 channel and que type 4 GPD that is processing |

**A1040244 HWTX1Q5CGPD DMA TX1 Que Type 5 Current GPD Address Register 00000000**

| <b>Bit</b>   | 31                   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  | TX1_Q5_CURR_GPD_ADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RO                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>   | 15                   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | TX1_Q5_CURR_GPD_ADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RO                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| <b>Bit(s)</b> | <b>Name</b>          | <b>Description</b>                                               |
|---------------|----------------------|------------------------------------------------------------------|
| 31:0          | TX1_Q5_CURR_GPD_ADDR | the address of TX1 channel and que type 5 GPD that is processing |

**A1040248 HWTX1Q6CGPD DMA TX1 Que Type 6 Current GPD Address Register 00000000**

| <b>Bit</b>   | 31                   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  | TX1_Q6_CURR_GPD_ADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RO                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>   | 15                   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | TX1_Q6_CURR_GPD_ADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RO                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| <b>Bit(s)</b> | <b>Name</b>          | <b>Description</b>                                    |
|---------------|----------------------|-------------------------------------------------------|
| 31:0          | TX1_Q6_CURR_GPD_ADDR | the address of TX1 channel and que type 6 GPD that is |

| Bit(s) | Name | Description |
|--------|------|-------------|
|        |      | processing  |

**A104024C HWTX1Q7CGPD DMA TX1 Que Type 7 Current GPD Address Register 00000000**

| Bit   | 31                   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | TX1_Q7_CURR_GPD_ADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15                   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | TX1_Q7_CURR_GPD_ADDR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name                 | Description                                                      |
|--------|----------------------|------------------------------------------------------------------|
| 31:0   | TX1_Q7_CURR_GPD_ADDR | the address of TX1 channel and que type 7 GPD that is processing |

**A10403F4 HSDIOCRCR HIF SDIO CRC status Register 00000000**

| Bit   | 31                | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|-------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  |                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15                | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | REG_CRC_STS_CYCLE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0    | REG_CRC_STS_CYCLE | In SDIO 3.0 spec. for SDR50 and SDR104 mode, the CRC status can be sent 2 to 8 cycles after one data block.<br>Firmware could write this register to change the response timing of SDIO IP. Default value is set to be 2 cycles after one data block.<br>0: 2 cycles after data block<br>1: 3 cycles after data block<br>2: 4 cycles after data block<br>3: 5 cycles after data block<br>4: 6 cycles after data block<br>5: 7 cycles after data block<br>6: 8 cycles after data block<br>7: 9 cycles after data block |

**A10403F8 HSDIORCR HIF SDIO Read Control Register 00000001**

| Bit    | 31 | 30 | 29 | 28 | 27 | 26 | 25                     | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                 |
|--------|----|----|----|----|----|----|------------------------|----|----|----|----|----|----|----|----|--------------------|
| Name   |    |    |    |    |    |    |                        |    |    |    |    |    |    |    |    |                    |
| Type   |    |    |    |    |    |    |                        |    |    |    |    |    |    |    |    |                    |
| Rese t |    |    |    |    |    |    |                        |    |    |    |    |    |    |    |    |                    |
| Bit    | 15 | 14 | 13 | 12 | 11 | 10 | 9                      | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                  |
| Name   |    |    |    |    |    |    | REG_SDIO_RD_TIMING_SEL |    |    |    |    |    |    |    |    | REG_TIMEOUT_NUM_EN |
| Type   |    |    |    |    |    |    | RW                     |    |    |    |    |    |    |    |    | RW                 |
| Rese t |    |    |    |    |    |    | 0                      | 0  |    |    |    |    |    |    |    | 1                  |

| Bit(s) | Name                   | Description                                                                                                                                                                                                                                                                                                                                                               |
|--------|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9:8    | REG_SDIO_RD_TIMING_SEL | <p>Use this register, if the firmware is unable to prepare the data on time for the host to read. The SDIO prefetch operation can be delayed according to the data depth in current RX FIFO. Firmware can write to this field to change the data depth constraint.</p> <p>2b'00: 4B<br/>2b'01: 8B<br/>2b'10:16B<br/>2b'11: 64B</p>                                        |
| 0      | REG_TIMEOUT_NUM_EN     | <p>Use this register, if the firmware is unable to prepare the data on time for the host to read. The SDIO read timing adjustment function is implemented to protect the read data underflow. Firmware can write 1 to enable and write 0 to disable the function.</p> <p>0: Disable SDIO Read timing adjust function.<br/>1: Enable SDIO Read timing adjust function.</p> |

### 13.5.2. Host domain register

Module name: SDIO\_SLV Base address: (+0h)

| Address  | Name            | Width (bits) | Register Functionality                        |
|----------|-----------------|--------------|-----------------------------------------------|
| 00000000 | <u>WCIR</u>     | 32           | WLAN Chip ID Register                         |
| 00000004 | <u>WHLPCR</u>   | 32           | WLAN HIF Low Power Control Register           |
| 00000008 | <u>WSDIOCSR</u> | 32           | WLAN SDIO Control Status Register (SDIO Only) |
| 0000000C | <u>WHCR</u>     | 32           | WLAN HIF Control Register                     |
| 00000010 | <u>WHISR</u>    | 32           | WLAN HIF Interrupt Status Register            |
| 00000014 | <u>WHIER</u>    | 32           | WLAN HIF Interrupt Enable Register            |
| 00000018 | <u>WHISR1</u>   | 32           | Reserve for WHISR1                            |
| 0000001C | <u>WHIER1</u>   | 32           | Reserve for WHIER1                            |
| 00000020 | <u>WASR</u>     | 32           | WLAN Abnormal Status Register                 |
| 00000024 | <u>WSICR</u>    | 32           | WLAN Software Interrupt Control Register      |

| Address  | Name            | Width (bits) | Register Functionality                                         |
|----------|-----------------|--------------|----------------------------------------------------------------|
| 00000028 | <u>WTSRo</u>    | 32           | <b>WLAN TX Status Register</b>                                 |
| 0000002C | <u>WTSR1</u>    | 32           | <b>WLAN TX Status Register</b>                                 |
| 00000030 | <u>WTDRo</u>    | 32           | <b>Reserve</b>                                                 |
| 00000034 | <u>WTDR1</u>    | 32           | <b>WLAN TX Data Register 1</b>                                 |
| 00000038 | <u>WTDR2</u>    | 32           | <b>Reserve for WTDR2</b>                                       |
| 0000003C | <u>WTDR3</u>    | 32           | <b>Reserve for WTDR3</b>                                       |
| 00000040 | <u>WTDR4</u>    | 32           | <b>Reserve for WTDR4</b>                                       |
| 00000044 | <u>WTDR5</u>    | 32           | <b>Reserve for WTDR5</b>                                       |
| 00000048 | <u>WTDR6</u>    | 32           | <b>Reserve for WTDR6</b>                                       |
| 0000004C | <u>WTDR7</u>    | 32           | <b>Reserve for WTDR7</b>                                       |
| 00000050 | <u>WRDRo</u>    | 32           | <b>WLAN RX Data Register 0</b>                                 |
| 00000054 | <u>WRDR1</u>    | 32           | <b>WLAN RX Data Register 1</b>                                 |
| 00000058 | <u>WRDR2</u>    | 32           | <b>Reserve</b>                                                 |
| 0000005C | <u>WRDR3</u>    | 32           | <b>Reserve</b>                                                 |
| 00000060 | <u>WRDR4</u>    | 32           | <b>Reserve for WRDR4</b>                                       |
| 00000064 | <u>WRDR5</u>    | 32           | <b>Reserve for WRDR5</b>                                       |
| 00000068 | <u>WRDR6</u>    | 32           | <b>Reserve for WRDR6</b>                                       |
| 0000006C | <u>WRDR7</u>    | 32           | <b>Reserve for WRDR7</b>                                       |
| 00000070 | <u>H2DSM0R</u>  | 32           | <b>Host to Device Send Mailbox 0 Register</b>                  |
| 00000074 | <u>H2DSM1R</u>  | 32           | <b>Host to Device Send Mailbox 1 Register</b>                  |
| 00000078 | <u>D2HRM0R</u>  | 32           | <b>Device to Host Receive Mailbox 0 Register</b>               |
| 0000007C | <u>D2HRM1R</u>  | 32           | <b>Device to Host Receive Mailbox 1 Register</b>               |
| 00000080 | <u>D2HRM2R</u>  | 32           | <b>Reserve</b>                                                 |
| 00000090 | <u>WRPLR</u>    | 32           | <b>WLAN RX Packet Length Register</b>                          |
| 00000094 | <u>WRPLR1</u>   | 32           | <b>WLAN RX Packet Length Register 1</b>                        |
| 00000098 | <u>WRPLR2</u>   | 32           | <b>Reserve for WRPLR2</b>                                      |
| 0000009C | <u>WRPLR3</u>   | 32           | <b>Reserve for WRPLR3</b>                                      |
| 000000A0 | <u>EHTCR</u>    | 32           | <b>EHPI transaction count register (EHPI only)</b>             |
| 000000AC | <u>WOLTCR</u>   | 32           | <b>On Line-Tuning Control Register</b>                         |
| 000000B0 | <u>WTMDR</u>    | 32           | <b>Test Mode Data Port</b>                                     |
| 000000B4 | <u>WTMCR</u>    | 32           | <b>Test Mode Control Register</b>                              |
| 000000B8 | <u>WTMDPCR0</u> | 32           | <b>Test Mode Data Pattern Control Register 0</b>               |
| 000000BC | <u>WTMDPCR1</u> | 32           | <b>Test Mode Data Pattern Control Register 1</b>               |
| 000000C0 | <u>FWDLDR</u>   | 32           | <b>Firmware Download Data Register</b>                         |
| 000000C4 | <u>FWDLDSAR</u> | 32           | <b>Firmware Download Destination Starting Address Register</b> |
| 000000C8 | <u>FWDLSR</u>   | 32           | <b>Firmware Download Status Register</b>                       |
| 000000CC | <u>FWDLCMRO</u> | 32           | <b>Firmware Download Customized Register 0</b>                 |
| 000000D0 | <u>FWDLCMR1</u> | 32           | <b>Firmware Download Customized Register 1</b>                 |
| 000000D4 | <u>WPLRCR</u>   | 32           | <b>WLAN Packet Length Report Control Register</b>              |
| 000000D8 | <u>WSR</u>      | 32           | <b>WLAN Snapshot Register</b>                                  |
| 000000F8 | <u>VSCR</u>     | 32           | <b>Version Control Register</b>                                |

| Address  | Name                  | Width (bits) | Register Functionality                              |
|----------|-----------------------|--------------|-----------------------------------------------------|
| 000000FC | <u>WSDIOAICR</u>      | 32           | Common SDIO Asynchronous Interrupt Control Register |
| 00000100 | <u>CLKIOCR T28LP</u>  | 32           | Clock Pad Macro IO Control Register                 |
| 00000104 | <u>CMDIOCR T28LP</u>  | 32           | Command Pad Macro IO Control Register               |
| 00000108 | <u>DAT0IOCR T28LP</u> | 32           | Data 0 Pad Macro IO Control Register                |
| 0000010C | <u>DAT1IOCR T28LP</u> | 32           | Data 1 Pad Macro IO Control Register                |
| 00000110 | <u>DAT2IOCR T28LP</u> | 32           | Data 2 Pad Macro IO Control Register                |
| 00000114 | <u>DAT3IOCR T28LP</u> | 32           | Data 3 Pad Macro IO Control Register                |
| 00000118 | <u>CLKDLYCR</u>       | 32           | Clock Pad Macro Delay Chain Control Register        |
| 0000011C | <u>CMDDLYCR</u>       | 32           | Command Pad Macro Delay Chain Control Register      |
| 00000120 | <u>ODATDLYCR</u>      | 32           | SDIO Output Data Delay Chain Control Register       |
| 00000124 | <u>IDATDLYCR1</u>     | 32           | SDIO Input Data Delay Chain Control Register 1      |
| 00000128 | <u>IDATDLYCR2</u>     | 32           | SDIO Input Data Delay Chain Control Register 2      |
| 0000012C | <u>ILCHCR</u>         | 32           | SDIO Input Data Latch Time Control Register         |
| 00000130 | <u>WTQCR0</u>         | 32           | WLAN TXQ Count Register 0                           |
| 00000134 | <u>WTQCR1</u>         | 32           | WLAN TXQ Count Register 1                           |
| 00000138 | <u>WTQCR2</u>         | 32           | WLAN TXQ Count Register 2                           |
| 0000013C | <u>WTQCR3</u>         | 32           | WLAN TXQ Count Register 3                           |
| 00000140 | <u>WTQCR4</u>         | 32           | WLAN TXQ Count Register 4                           |
| 00000144 | <u>WTQCR5</u>         | 32           | WLAN TXQ Count Register 5                           |
| 00000148 | <u>WTQCR6</u>         | 32           | WLAN TXQ Count Register 6                           |
| 0000014C | <u>WTQCR7</u>         | 32           | WLAN TXQ Count Register 7                           |
| 00000154 | <u>SWPCDBGR</u>       | 32           | WLAN PC Value debug register                        |
| 00000158 | <u>DSIOCR</u>         | 32           | DS Pad Macro IO Control Register                    |

| 00000000 |               | WLAN Chip ID Register |    |    |    |    |    |    |    |    |              | 00106630           |             |    |    |    |
|----------|---------------|-----------------------|----|----|----|----|----|----|----|----|--------------|--------------------|-------------|----|----|----|
| Bit      | 31            | 30                    | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21           | 20                 | 19          | 18 | 17 | 16 |
| Name     | DEVICE_STATUS |                       |    |    |    |    |    |    |    |    | W_FU_NC_R_DY | PO_R_I_ND_ICA_TO_R | REVISION_ID |    |    |    |
| Type     | RO            |                       |    |    |    |    |    |    |    |    | RO           | W1_C               | RO          |    |    |    |
| Reset    | 0             | 0                     | 0  | 0  | 0  | 0  | 0  | 0  |    |    | 0            | 1                  | 0           | 0  | 0  | 0  |
| Bit      | 15            | 14                    | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5            | 4                  | 3           | 2  | 1  | 0  |
| Name     | CHIP_ID       |                       |    |    |    |    |    |    |    |    |              |                    |             |    |    |    |
| Type     | RO            |                       |    |    |    |    |    |    |    |    |              |                    |             |    |    |    |
| Reset    | 0             | 1                     | 1  | 0  | 0  | 1  | 1  | 0  | 0  | 0  | 1            | 1                  | 0           | 0  | 0  | 0  |

---

| Bit(s) | Name | Description |
|--------|------|-------------|
|--------|------|-------------|

---

| Bit(s) | Name          | Description                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24  | DEVICE_STATUS | These status bits are defined by users and could be read by host driver via SDIO bus interface. For example, watch dog reset status could be one that could be read by host driver even when there is no AHB clock in SDIO controller.                                                                                                                                                                                               |
| 21     | W_FUNC_RDY    | Indicate that WLAN functional block has finished its initial procedure and it is ready for normal operation. This is a sticky bit of HWFCR.W_FUNC_RDY. Driver will keep polling this bit on initialization. Once after FW is ready and set corresponding bit in FW, driver can do following control to FW.<br>0: WLAN functional block is not ready for normal operation.<br>1: WLAN functional block is ready for normal operation. |
| 20     | POR_INDICATOR | This bit indicates a reset occurs including external pin reset, power detect reset, power on reset, SDIO CCCR(0x06).Bit[3] reset (only in SDIO). Write 1 to clear this bit. Writing 0 does nothing.                                                                                                                                                                                                                                  |
| 19:16  | REVISION_ID   | Revision ID                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 15:0   | CHIP_ID       | Chip ID                                                                                                                                                                                                                                                                                                                                                                                                                              |

| WLAN HIF Low Power Control Register |    |    |    |    |    |    |              |              |    |    |    |    |    |                |                |    |
|-------------------------------------|----|----|----|----|----|----|--------------|--------------|----|----|----|----|----|----------------|----------------|----|
| Bit                                 | 31 | 30 | 29 | 28 | 27 | 26 | 25           | 24           | 23 | 22 | 21 | 20 | 19 | 18             | 17             | 16 |
| Name                                |    |    |    |    |    |    |              |              |    |    |    |    |    |                |                |    |
| Type                                |    |    |    |    |    |    |              |              |    |    |    |    |    |                |                |    |
| Reset                               |    |    |    |    |    |    |              |              |    |    |    |    |    |                |                |    |
| Bit                                 | 15 | 14 | 13 | 12 | 11 | 10 | 9            | 8            | 7  | 6  | 5  | 4  | 3  | 2              | 1              | 0  |
| Name                                |    |    |    |    |    |    | W_FW_OWN     | W_FW_OWN     |    |    |    |    |    | W_INT_E_N_CL_R | W_INT_E_N_SE_T |    |
| Type                                |    |    |    |    |    |    | WN_R_EQ_C_LR | WN_R_EQ_S_FT |    |    |    |    |    | W1S            | W1S            |    |
| Reset                               |    |    |    |    |    |    | W1S          | W1S          |    |    |    |    |    | W1S            | W1S            |    |

| Bit(s) | Name             | Description                                                                                                                                                                                                                                                                                                                                          |
|--------|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9      | W_FW_OWN_REQ_CLR | Write 1 to this bit to request firmware to return the ownership of chip WLAN function to host driver. Write 0 has no meaning (Refer chapter "Power management" for details). Read always return 0. This bit will be set on initial, or by firmware written 1 to HWFICR.FW_OWN_BACK_INT_SET or any driver-domain WLAN interrupts.                     |
| 8      | W_FW_OWN_REQ_SET | Write 1 to this bit to transfer ownership of chip WLAN function to firmware. Write 0 has no meaning (Refer chapter "Power management" for details). Host driver should set this bit to give ownership to firmware only when host driver has ownership. Read will get the status of WLAN_DRV_OWN. WLAN_DRV_OWN indicates that software driver has the |

| Bit(s) | Name         | Description                                                                                                                                                                                                                                                                                                                                                               |
|--------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1      | W_INT_EN_CLR | ownership of chip WLAN sub-system.<br>0: WLAN driver doesn't have ownership<br>1: WLAN driver has ownership<br><b>Write 0 has no meaning, and write 1 to clear WLAN interrupt enable signal.</b><br>Read always return 0.                                                                                                                                                 |
| 0      | W_INT_EN_SET | <b>Write 0 has no meaning, and write 1 to set WLAN interrupt enable signal.</b><br>Read will get the status of W_INT_EN.<br><br>W_INT_EN indicates the current value of WLAN interrupt enable signal. This enable signal is used for controlling the output of WLAN interrupt signal.<br>0: WLAN interrupt can't output to host.<br>1: WLAN interrupt can output to host. |

| WLAN SDIO Control Status Register (SDIO Only) |    |    |    |    |    |    |    |    |    |    |    |                                                                          |                                                    |                                                    |                                         |                                                     |
|-----------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|--------------------------------------------------------------------------|----------------------------------------------------|----------------------------------------------------|-----------------------------------------|-----------------------------------------------------|
| Bit                                           | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20                                                                       | 19                                                 | 18                                                 | 17                                      | 16                                                  |
| Nam e                                         |    |    |    |    |    |    |    |    |    |    |    |                                                                          |                                                    |                                                    |                                         |                                                     |
| Type                                          |    |    |    |    |    |    |    |    |    |    |    |                                                                          |                                                    |                                                    |                                         |                                                     |
| Rese t                                        |    |    |    |    |    |    |    |    |    |    |    |                                                                          |                                                    |                                                    |                                         |                                                     |
| Bit                                           | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4                                                                        | 3                                                  | 2                                                  | 1                                       | 0                                                   |
| Nam e                                         |    |    |    |    |    |    |    |    |    |    |    | <b>DB<br/>_C<br/>MD<br/>7_<br/>RE<br/>SE<br/>LE<br/>CT<br/>_D<br/>IS</b> | <b>DB<br/>_W<br/>R_<br/>BU<br/>SY<br/>_E<br/>N</b> | <b>DB<br/>_R<br/>D_<br/>BU<br/>SY<br/>_E<br/>N</b> | <b>SDI<br/>O_I<br/>NT<br/>_C<br/>TL</b> | <b>SDI<br/>O_<br/>RE<br/>I<br/>NIT<br/>_E<br/>N</b> |
| Type                                          |    |    |    |    |    |    |    |    |    |    |    | RW                                                                       | RW                                                 | RW                                                 | RW                                      | RO                                                  |
| Rese t                                        |    |    |    |    |    |    |    |    |    |    |    | 0                                                                        | 1                                                  | 1                                                  | 0                                       | 1                                                   |

| Bit(s) | Name                 | Description                                                                                                                                                                                                                                                                                                                                                                         |
|--------|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4      | DB_CMD7_RESELECT_DIS | <b>Control the cmd7 with response when the card is during re-select</b><br>0: Host use cmd7 reselect and card will have response.<br>1: Host use cmd7 reselect and card will NOT have response.                                                                                                                                                                                     |
| 3      | DB_WR_BUSY_EN        | <b>Write busy function control bit. If the available space of internal TX FIFO is smaller than the pre-defined maximum block size, the write busy will be asserted. The write busy function can be used only when the block size is smaller than pre-defined FIFO size (that is maximum block size).</b><br>0: DMA write busy function disable<br>1: DMA write busy function enable |
| 2      | DB_RD_BUSY_EN        | <b>Read busy function control bit. If the usage of internal RX FIFO is smaller than the pre-defined maximum block size, the read busy would be triggered except the data is the last part of this transaction. The read busy function can be used only when the block size set is smaller than pre-defined FIFO size (i.e. max block size).</b>                                     |

| Bit(s) | Name            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1      | SDIO_INT_CTL    | <p>0: DMA read busy function disable<br/>1: DMA read busy function enable</p> <p><b>Asynchronous interrupt is supported in SDIO 4-bit mode</b><br/>0: Not supported; The host should switch to 1-bit mode before it turns off SD clock. Device can wake up host via 1-bit mode asynchronous interrupt. (according to SDIO v2.0 spec)<br/>1: Supported; The host could send asynchronous interrupt to host during asynchronous interrupt period so that the host does not need to switch to 1-bit mode before it turns off SD clock. (according to SDIO v3.0 spec)</p> |
| 0      | SDIO_RE_INIT_EN | <p><b>When asserted, this bit is used to let SDIO IP back to idle state when a new SDIO CMD 5 is received.</b></p> <p>Default value can use fixed default value or use an engine to set or use an external bus for it.</p>                                                                                                                                                                                                                                                                                                                                            |

| 0000000C WHCR WLAN HIF Control Register 00000000 |    |    |                    |    |    |    |    |    |    |    |    |    |    |                           |                                      |                      |
|--------------------------------------------------|----|----|--------------------|----|----|----|----|----|----|----|----|----|----|---------------------------|--------------------------------------|----------------------|
| Bit                                              | 31 | 30 | 29                 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18                        | 17                                   | 16                   |
| Name                                             |    |    |                    |    |    |    |    |    |    |    |    |    |    |                           |                                      | RX_E_NH_AN_CE_M_OD_E |
| Type                                             |    |    |                    |    |    |    |    |    |    |    |    |    |    |                           |                                      | RW                   |
| Reset                                            |    |    |                    |    |    |    |    |    |    |    |    |    |    |                           |                                      | 0                    |
| Bit                                              | 15 | 14 | 13                 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2                         | 1                                    | 0                    |
| Name                                             |    |    | MAX_HIF_RX_LEN_NUM |    |    |    |    |    |    |    |    |    |    | RP_T_OWN_RX_PACKET_LENGTH | RECV_MAILBOX_AIL_BO_X_RD_C_LR_C_TR_L |                      |
| Type                                             |    |    | RW                 |    |    |    |    |    |    |    |    |    |    | RW                        | RW                                   | RW                   |
| Reset                                            |    |    | 0                  | 0  | 0  | 0  | 0  | 0  |    |    |    |    |    | 0                         | 0                                    | 0                    |

| Bit(s) | Name                  | Description                                                                                                                                                                                                                                                                                               |
|--------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16     | RX_ENHANCE_MODE       | <p><b>Enable the read of TX count status, RX length, and mailbox information in RX packet enhance mode. Refer chapter 3.4 for more details.</b></p> <p>0: Disables RX packet enhanced mode<br/>1: Enables the read of TX count status, RX length, and mailbox information in RX packet enhanced mode.</p> |
| 13:8   | MAX_HIF_RX_LEN_NUM    | <p><b>The maximum number of SDIO controller to report the per-queue RX packets length via INT/ RX enhanced mode.</b></p> <p>0: report entire 64 RX packets length in the same RX queue without limitation.<br/>Others (N): report at most N RX packet lengths for each RX queue</p>                       |
| 3      | RPT_OWN_RX_PACKET_LEN | <p><b>This field is to control the RX packet report length and structure during enhance mode. If this bit is set to 1, each RX queue can report its own length according to the setting in WPLRCR. Also, the total report length would be</b></p>                                                         |

| Bit(s) | Name                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2      | RECV_MAILBOX_RD_CLR_EN | <p>changed if this bit is set. Host driver should parse the enhanced mode status according to the length setting in WPLRCR to get correct information.</p> <p>0: disable the function that each RX queue can report its own packet length and the maximal report length is constrained by max_hif_rx_len_num field in WHCR</p> <p>1: enable the function that each RX queue can report its own packet length and the maximal report length can be different by each queue according to the setting in WPLRCR</p> <p><b>This is to control whether the received mail-box (D2HRMoR, D2HRM1R) will be read cleared or not (this include read from enhance mode structure).</b></p> <p>1: read clear</p> <p>0: no effect after read</p> |
| 1      | W_INT_CLR_CTRL         | <p><b>This bit is used to select the clear mechanism of WLAN interrupt statue (WHISR).</b></p> <p>0: Read clear</p> <p>1: Write 1 clear</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

| 00000010 WHISR WLAN HIF Interrupt Status Register 00000000 |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------------------------------------------------------------|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit                                                        | 31         | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name                                                       | D2H_SW_INT |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                                                       | RC         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset                                                      | 0          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |    |
| Bit                                                        | 15         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name                                                       | D2H_SW_INT |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                                                       | RC         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset                                                      | 0          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |    |

| Bit(s) | Name            | Description                                                                                                                                                                                                             |
|--------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8   | D2H_SW_INT      | <p><b>This field is used for software interrupt for WLAN function in FW to host driver direction.</b></p> <p>WLAN firmware writes 1s to HWFICR.Bit[31:8] will set corresponding bit field.</p>                          |
| 7      | FW_OWN_BACK_INT | <p><b>Firmware has returned the ownership to host driver. This field is set with driver own-back only.</b></p> <p>Firmware write 1 to HWFICR. Bit[4] will set this bit.</p>                                             |
| 6      | ABNORMAL_INT    | <p><b>Abnormal event interrupt.</b></p> <p>The abnormal status will be shown in WASR, which includes Data overflow of WLAN TXo and TX1 port.<br/>Data underflow of WLAN RXo and RX1 port.<br/>FW_OWN_INVALID_ACCESS</p> |
| 4      | RX3_DONE_INT    | <p><b>When any of the RX length data of RX3 is existed in HIF RX length FIFO, this bit will be asserted.</b></p>                                                                                                        |
| 3      | RX2_DONE_INT    | <p><b>When any of the RX length data of RX2 is existed in HIF RX length FIFO, this bit will be asserted.</b></p>                                                                                                        |
| 2      | RX1_DONE_INT    | <p><b>When any of the RX length data of RX1 is existed in HIF RX length FIFO, this bit will be asserted.</b></p>                                                                                                        |
| 1      | RXo_DONE_INT    | <p><b>When any of the RX length data of RXo is existed in HIF RX length FIFO, this bit will be asserted.</b></p>                                                                                                        |

| Bit(s) | Name        | Description                                                                                                  |
|--------|-------------|--------------------------------------------------------------------------------------------------------------|
| 0      | TX_DONE_INT | If WTSRo or WTSR1 is not 0, this bit will be set.<br>0: WTSRo and WTSR1 is 0.<br>1: WTSRo or WTSR1 is not 0. |

| <b>00000014 WHIER WLAN HIF Interrupt Enable Register 00000000</b> |                      |    |    |    |    |    |    |            |             |            |            |            |            |             |                |    |
|-------------------------------------------------------------------|----------------------|----|----|----|----|----|----|------------|-------------|------------|------------|------------|------------|-------------|----------------|----|
| Bit                                                               | 31                   | 30 | 29 | 28 | 27 | 26 | 25 | 24         | 23          | 22         | 21         | 20         | 19         | 18          | 17             | 16 |
| <b>Name</b>                                                       | <b>D2H_SW_INT_EN</b> |    |    |    |    |    |    |            |             |            |            |            |            |             |                |    |
| <b>Type</b>                                                       | RW                   |    |    |    |    |    |    |            |             |            |            |            |            |             |                |    |
| <b>Reset</b>                                                      | 0                    | 0  | 0  | 0  | 0  | 0  | 0  | 0          | 0           | 0          | 0          | 0          | 0          | 0           | 0              |    |
| <b>Bit</b>                                                        | 15                   | 14 | 13 | 12 | 11 | 10 | 9  | 8          | 7           | 6          | 5          | 4          | 3          | 2           | 1              | 0  |
| <b>Name</b>                                                       | <b>D2H_SW_INT_EN</b> |    |    |    |    |    |    |            | <b>FW_O</b> | <b>AB</b>  | <b>RX</b>  | <b>RX</b>  | <b>RX</b>  | <b>RX</b>   | <b>TX_D</b>    |    |
|                                                                   |                      |    |    |    |    |    |    | <b>WN</b>  | <b>NO</b>   | <b>3_D</b> | <b>2_D</b> | <b>1_D</b> | <b>0_D</b> | <b>NE_I</b> | <b>ON_E_I</b>  |    |
|                                                                   |                      |    |    |    |    |    |    | <b>B</b>   | <b>RM</b>   | <b>DO</b>  | <b>DO</b>  | <b>DO</b>  | <b>DO</b>  | <b>NE_I</b> | <b>NT_E</b>    |    |
|                                                                   |                      |    |    |    |    |    |    | <b>AC</b>  | <b>AL</b>   | <b>NE</b>  | <b>NE</b>  | <b>NE</b>  | <b>NE</b>  | <b>I_N</b>  | <b>INT_E_N</b> |    |
|                                                                   |                      |    |    |    |    |    |    | <b>K_I</b> | <b>I_N</b>  | <b>I</b>   | <b>I</b>   | <b>I</b>   | <b>I</b>   | <b>NT_E</b> | <b>NT_E_N</b>  |    |
|                                                                   |                      |    |    |    |    |    |    | <b>NT</b>  | <b>E</b>    | <b>NT</b>  | <b>E</b>   | <b>NT</b>  | <b>E</b>   | <b>NE</b>   | <b>INT_E_N</b> |    |
|                                                                   |                      |    |    |    |    |    |    | <b>E</b>   | <b>N</b>    | <b>E</b>   | <b>N</b>   | <b>E</b>   | <b>N</b>   | <b>NE</b>   | <b>INT_E_N</b> |    |
| <b>Type</b>                                                       | RW                   |    |    |    |    |    |    |            | RW          | RW         | RW         | RW         | RW         | RW          | RW             | RW |
| <b>Reset</b>                                                      | 0                    | 0  | 0  | 0  | 0  | 0  | 0  | 0          | 0           | 0          | 0          | 0          | 0          | 0           | 0              | 0  |

| Bit(s) | Name               | Description                                                                                                                                                                                                                                            |
|--------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:8   | D2H_SW_INT_EN      | <b>WLAN host interrupt output control bits.</b><br>If any bit is<br>0: Mask the WLAN related bit interrupt output, corresponding bits will be still written to WHISR without triggering interrupt.<br>1: Enable the WLAN related bit interrupt output. |
| 7      | FW_OWN_BACK_INT_EN | <b>WLAN host interrupt output control bits.</b><br>If any bit is<br>0: Mask the WLAN related bit interrupt output, corresponding bits will be still written to WHISR without triggering interrupt.<br>1: Enable the WLAN related bit interrupt output. |
| 6      | ABNORMAL_INT_EN    | <b>WLAN host interrupt output control bits.</b><br>If any bit is<br>0: Mask the WLAN related bit interrupt output, corresponding bits will be still written to WHISR without triggering interrupt.<br>1: Enable the WLAN related bit interrupt output. |
| 4      | RX3_DONE_INT_EN    | <b>WLAN host interrupt output control bits.</b><br>If any bit is<br>0: Mask the WLAN related bit interrupt output, corresponding bits will be still written to WHISR without triggering interrupt.<br>1: Enable the WLAN related bit interrupt output. |
| 3      | RX2_DONE_INT_EN    | <b>WLAN host interrupt output control bits.</b><br>If any bit is<br>0: Mask the WLAN related bit interrupt output, corresponding bits will be still written to WHISR without triggering interrupt.<br>1: Enable the WLAN related bit interrupt output. |
| 2      | RX1_DONE_INT_EN    | <b>WLAN host interrupt output control bits.</b><br>If any bit is<br>0: Mask the WLAN related bit interrupt output, corresponding bits will be still written to WHISR without triggering interrupt.<br>1: Enable the WLAN related bit interrupt output. |
| 1      | RXo_DONE_INT_EN    | <b>WLAN host interrupt output control bits.</b><br>If any bit is                                                                                                                                                                                       |

| Bit(s) | Name           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | TX_DONE_INT_EN | <p>0: Mask the WLAN related bit interrupt output, corresponding bits will be still written to WHISR without triggering interrupt.</p> <p>1: Enable the WLAN related bit interrupt output.</p> <p><b>WLAN host interrupt output control bits.</b></p> <p>If any bit is</p> <p>0: Mask the WLAN related bit interrupt output, corresponding bits will be still written to WHISR without triggering interrupt.</p> <p>1: Enable the WLAN related bit interrupt output.</p> |
|        |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

| 00000018 WHISR1 Reserve for WHISR1 00000000 |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|---------------------------------------------|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit                                         | 31          | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name                                        | RESV_WHISR1 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                                        | RO          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset                                       | 0           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |    |
| Bit                                         | 15          | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  |    |
| Name                                        | RESV_WHISR1 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                                        | RO          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset                                       | 0           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |    |

| Bit(s) | Name        | Description |
|--------|-------------|-------------|
| 31:0   | RESV_WHISR1 | RESV_WHISR1 |

| 0000001C WHIER1 Reserve for WHIER1 00000000 |             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|---------------------------------------------|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit                                         | 31          | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name                                        | RESV_WHIER1 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                                        | RO          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset                                       | 0           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |    |
| Bit                                         | 15          | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  |    |
| Name                                        | RESV_WHIER1 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                                        | RO          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset                                       | 0           | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |    |

| Bit(s) | Name        | Description |
|--------|-------------|-------------|
| 31:0   | RESV_WHIER1 | RESV_WHIER1 |

| 00000020 WASR WLAN Abnormal Status Register 00000000 |                          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------------------------------------------------------|--------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit                                                  | 31                       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name                                                 | FW_O_WN_I_NV_ALI_D_AC_CE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                                                 | RO                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset                                                | 0                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Type   |    |    |    |    |                        |                        |                        |                        |   |   |   |   |   |   |                      | SS                   |
|--------|----|----|----|----|------------------------|------------------------|------------------------|------------------------|---|---|---|---|---|---|----------------------|----------------------|
| Rese t |    |    |    |    |                        |                        |                        |                        |   |   |   |   |   |   |                      | RC                   |
| Bit    | 15 | 14 | 13 | 12 | 11                     | 10                     | 9                      | 8                      | 7 | 6 | 5 | 4 | 3 | 2 | 1                    | 0                    |
| Name   |    |    |    |    | RX<br>3_ UN DE RF LO W | RX<br>2_ UN DE RF LO W | RX<br>1_ UN DE RF LO W | RX<br>0_ UN DE RF LO W |   |   |   |   |   |   | TX<br>1_ OV ER FL OW | TX<br>0_ OV ER FL OW |
| Type   |    |    |    |    | RC                     | RC                     | RC                     | RC                     |   |   |   |   |   |   | RC                   | RC                   |
| Rese t |    |    |    |    | o                      | o                      | o                      | o                      |   |   |   |   |   |   | o                    | o                    |

| Bit(s) | Name                  | Description                                                                                                                                                                                                         |
|--------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16     | FW_OWN_INVALID_ACCESS | <b>It will be asserted when register other than WCIR, WHLPCR, WSPICSR, WSDIOCSR, WEHPICSR, and firmware download relative registers are accessed when FW own = 1</b><br>It is purely for host driver debug purpose. |
| 11     | RX3_UNDERFLOW         | <b>Data underflow of WLAN RX3 port.</b>                                                                                                                                                                             |
| 10     | RX2_UNDERFLOW         | <b>Data underflow of WLAN RX2 port.</b>                                                                                                                                                                             |
| 9      | RX1_UNDERFLOW         | <b>Data underflow of WLAN RX1 port.</b>                                                                                                                                                                             |
| 8      | RX0_UNDERFLOW         | <b>Data underflow of WLAN RX0 port.</b>                                                                                                                                                                             |
| 1      | TX1_OVERFLOW          | <b>Data overflow of WLAN TX1 port.</b>                                                                                                                                                                              |
| 0      | TX0_OVERFLOW          | <b>Data overflow of WLAN TX0 port.</b>                                                                                                                                                                              |

**00000024 WSICR****WLAN Software Interrupt Control Register****00000000**

| Bit    | 31             | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name   | H2D_SW_INT_SET |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type   | WiS            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t | 0              | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit    | 15             | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name   |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type   |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit(s) | Name           | Description                                                                                                                                                                                                                      |
|--------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16  | H2D_SW_INT_SET | <b>Host driver writes 1s will set HWFISR.<br/>HOST_DRIVER_INT. Writing 0 does nothing.<br/>Read always returns 0.<br/>This is used as a communication between FW to driver, with interrupt functionality to SDIO controller.</b> |

**00000028 WTSRo****WLAN TX Status Register****00000000**

| Bit    | 31      | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23      | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------|---------|----|----|----|----|----|----|----|---------|----|----|----|----|----|----|----|
| Name   | TQ3_CNT |    |    |    |    |    |    |    | TQ2_CNT |    |    |    |    |    |    |    |
| Type   | RC      |    |    |    |    |    |    |    | RC      |    |    |    |    |    |    |    |
| Rese t | 0       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0       | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name    | Description                                                                                                                                                             |
|--------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24  | TQ3_CNT | <p><b>This field indicates the released packet count of TQ3 during two WTSRo read access.</b></p> <p>This field is cleared by read operation. Write has no meaning.</p> |
| 23:16  | TQ2_CNT | <p><b>This field indicates the released packet count of TQ2 during two WTSRo read access.</b></p> <p>This field is cleared by read operation. Write has no meaning.</p> |
| 15:8   | TQ1_CNT | <p><b>This field indicates the released packet count of TQ1 during two WTSRo read access.</b></p> <p>This field is cleared by read operation. Write has no meaning.</p> |
| 7:0    | TQ0_CNT | <p><b>This field indicates the released packet count of TQ0 during two WTSRo read access.</b></p> <p>This field is cleared by read operation. Write has no meaning.</p> |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                                                                                                                           |
|---------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24         | TQ7_CNT     | <b>This field indicates the released packet count of TQ7 during two WTSRo read access.</b><br>This field is cleared by read operation. Write has no meaning. |
| 23:16         | TQ6_CNT     | <b>This field indicates the released packet count of TQ6 during two WTSRo read access.</b><br>This field is cleared by read operation. Write has no meaning. |
| 15:8          | TQ5_CNT     | <b>This field indicates the released packet count of TQ5 during two WTSR1 read access.</b><br>This field is cleared by read operation. Write has no meaning. |
| 7:0           | TQ4_CNT     | <b>This field indicates the released packet count of TQ4 during two WTSR1 read access.</b><br>This field is cleared by read operation. Write has no meaning. |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                        |
|---------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0          | TXo_DATA    | <p><b>TXo write data port. Read always return 0.</b></p> <p>Data must be padded to multiples of block when the data to write is more than the size of a single block. Writing data with multiple blocks in one transaction and the remaining in another with byte mode is prohibited.</p> |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                        |
|---------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0          | TX1_DATA    | <p><b>TX1 write data port. Read always return 0.</b></p> <p>Data must be padded to multiples of block when the data to write is more than the size of a single block. Writing data with multiple blocks in one transaction and the remaining in another with byte mode is prohibited.</p> |

| <b>Bit(s)</b> | <b>Name</b>       | <b>Description</b> |
|---------------|-------------------|--------------------|
| 31:0          | <b>RESV_WTDR2</b> | <b>RESV_WTDR2</b>  |

**0000003C WTDR3****Reserve for WTDR3****00000000**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**Bit(s)****Name****Description**

31:0 RESV\_WTDR3

**00000040 WTDR4****Reserve for WTDR4****00000000**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**Bit(s)****Name****Description**

31:0 RESV\_WTDR4

**00000044 WTDR5****Reserve for WTDR5****00000000**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**Bit(s)****Name****Description**

31:0 RESV\_WTDR5

**00000048 WTDR6****Reserve for WTDR6****00000000**

| Bit   | 31         | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | RESV_WTDR6 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | WO         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | RESV_WTDR6 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | WO         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**Bit(s)**

| Bit(s) | Name       | Description |
|--------|------------|-------------|
| 31:0   | RESV_WTDR6 | RESV_WTDR6  |

**0000004C WTDR7****Reserve for WTDR7****00000000**

| Bit   | 31         | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | RESV_WTDR7 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | WO         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | RESV_WTDR7 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | WO         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**Bit(s)**

| Bit(s) | Name       | Description |
|--------|------------|-------------|
| 31:0   | RESV_WTDR7 | RESV_WTDR7  |

**00000050 WRDRO****WLAN RX Data Register 0****00000000**

| Bit   | 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | RXo_DATA |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15       | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | RXo_DATA |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**Bit(s)**

| Bit(s) | Name     | Description                              |
|--------|----------|------------------------------------------|
| 31:0   | RXo_DATA | RXo read data port. Write has no effect. |

The RXo data port support data aggregation. Driver should read the entire RX packets by last SDIO controller indicated information.

The number of total RX aggregation packets is restricted by WHCR.  
MAX\_HIF\_RX\_LEN\_NUM.  
(details is in chapter 3.1):

| Bit(s) | Name | Description                                                                                                                                                                                                                                                    |
|--------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |      | Length to read must be extended to multiples of block when the data to read is more than the size of a single block. Reading data with multiple blocks in one transaction and the remaining in another with byte mode is prohibited.                           |
|        |      | Also as long as host driver knows the total available packet number and length via enhanced interrupt response and/or RX packet enhanced mode, host driver must read all RX packets in a single transaction. Reading for partial packets is prohibited either. |

| <b>00000054 WRDR1</b> |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>WLAN RX Data Register 1</b> |     |    |    |    |    |    |    |   |   |   |   |   |   |   |   | <b>00000000</b> |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-----------------------|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------------------|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----------------|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Bit                   | 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                             | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1               | 0 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name                  | RX1_DATA |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Type                           | RO  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |                 |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type                  | RO       |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Rese                           | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |                 |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name                  | RX1_DATA |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Type                           | RO  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |                 |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type                  | RO       |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Rese                           | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |                 |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bit(s) | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | RX1_DATA | <b>RX1 read data port. Write has no effect.</b><br>The RX1 data port support data aggregation. Driver should read the entire RX packets by last SDIO controller indicated information. The number of total RX aggregation packets is restricted by WHCR. MAX_HIF_RX_LEN_NUM.<br>(details is in chapter 3.1):<br><br>Data length to read must be extended to multiples of block when the data to read is more than the size of a single block. Reading data with multiple blocks in one transaction and the remaining in another with byte mode is prohibited. |
|        |          | Also as long as host driver knows the total available packet number and length via enhanced interrupt response and/or RX packet enhanced mode, host driver must read all RX packets in a single transaction. Reading for partial packets is prohibited either.                                                                                                                                                                                                                                                                                                |

| <b>00000058 WRDR2</b> |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>WLAN RX Data Register 2</b> |     |    |    |    |    |    |    |   |   |   |   |   |   |   |   | <b>00000000</b> |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-----------------------|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------------------|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----------------|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Bit                   | 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                             | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1               | 0 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name                  | RX2_DATA |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Type                           | RO  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |                 |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type                  | RO       |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Rese                           | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |                 |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name                  | RX2_DATA |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Type                           | RO  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |                 |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type                  | RO       |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Rese                           | 0   | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |                 |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| t |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|

| Bit(s) | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | RX2_DATA | <p><b>RX2 read data port. Write has no effect.</b></p> <p>The RX2 data port support data aggregation. Driver should read the entire RX packets by last SDIO controller indicated information. The number of total RX aggregation packets is restricted by WHCR. MAX_HIF_RX_LEN_NUM. (details is in chapter 3.1):</p> <p>Data length to read must be extended to multiples of block when the data to read is more than the size of a single block. Reading data with multiple blocks in one transaction and the remaining in another with byte mode is prohibited.</p> <p>Also as long as host driver knows the total available packet number and length via enhanced interrupt response and/or RX packet enhanced mode, host driver must read all RX packets in a single transaction. Reading for partial packets is prohibited either.</p> |

| <b>0000005C WRDR3</b> |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>WLAN RX Data Register 3</b> |     |    |    |    |    |    |    |   |   |   |   |   |   |   |   | <b>00000000</b> |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-----------------------|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------------------|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|-----------------|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Bit                   | 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                             | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1               | 0 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name                  | RX3_DATA |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Type                           | RO  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |                 |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Rese t                | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                              |     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |                 |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name                  | RX3_DATA |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Type                           | RO  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |                 |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Rese t                | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                              |     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |                 |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bit(s) | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | RX3_DATA | <p><b>RX3 read data port. Write has no effect.</b></p> <p>The RX3 data port support data aggregation. Driver should read the entire RX packets by last SDIO controller indicated information. The number of total RX aggregation packets is restricted by WHCR. MAX_HIF_RX_LEN_NUM. (details is in chapter 3.1):</p> <p>Data length to read must be extended to multiples of block when the data to read is more than the size of a single block. Reading data with multiple blocks in one transaction and the remaining in another with byte mode is prohibited.</p> <p>Also as long as host driver knows the total available packet number and length via enhanced interrupt response and/or RX packet enhanced mode, host driver must read all RX packets in a single transaction. Reading for partial packets is prohibited either.</p> |

| <b>00000060 WRDR4</b> |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>Reserve for WRDR4</b> |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>00000000</b> |    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-----------------------|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------------|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|----|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Bit                   | 31         | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                       | Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17              | 16 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Name                  | RESV_WRDR4 |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Type                     | RO  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Rese t                | 0          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                        |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

|        |            |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------|------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Type   | RO         |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Rese t | 0          | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Bit    | 15         | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name   | RESV_WRDR4 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type   | RO         |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Rese t | 0          | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| Bit(s) | Name       | Description |
|--------|------------|-------------|
| 31:0   | RESV_WRDR4 | RESV_WRDR4  |

|                 |              |                          |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-----------------|--------------|--------------------------|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>00000064</b> | <b>WRDR5</b> | <b>Reserve for WRDR5</b> | <b>00000000</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit             | 31           | 30                       | 29              | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Nam e           | RESV_WRDR5   |                          |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type            | RO           |                          |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t          | 0            | 0                        | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit             | 15           | 14                       | 13              | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Nam e           | RESV_WRDR5   |                          |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type            | RO           |                          |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t          | 0            | 0                        | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name       | Description |
|--------|------------|-------------|
| 31:0   | RESV_WRDR5 | RESV_WRDR5  |

|                 |              |                          |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-----------------|--------------|--------------------------|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>00000068</b> | <b>WRDR6</b> | <b>Reserve for WRDR6</b> | <b>00000000</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit             | 31           | 30                       | 29              | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Nam e           | RESV_WRDR6   |                          |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type            | RO           |                          |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t          | 0            | 0                        | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit             | 15           | 14                       | 13              | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Nam e           | RESV_WRDR6   |                          |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type            | RO           |                          |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t          | 0            | 0                        | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name       | Description |
|--------|------------|-------------|
| 31:0   | RESV_WRDR6 | RESV_WRDR6  |

|                 |              |                          |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-----------------|--------------|--------------------------|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>0000006C</b> | <b>WRDR7</b> | <b>Reserve for WRDR7</b> | <b>00000000</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit             | 31           | 30                       | 29              | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Nam e           | RESV_WRDR7   |                          |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type            | RO           |                          |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t          | 0            | 0                        | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b> |
|---------------|-------------|--------------------|
| 31:0          | RESV_WRDR7  | RESV_WRDR7         |

| Bit(s) | Name    | Description                                                                                                                |
|--------|---------|----------------------------------------------------------------------------------------------------------------------------|
| 31:0   | H2D_SMo | This register is used by host driver to transmit data to SDIO controller, which will be updated to H2DRMOR and read by FW. |

| Bit(s) | Name    | Description                                                                                                                |
|--------|---------|----------------------------------------------------------------------------------------------------------------------------|
| 31:0   | H2D_SM1 | This register is used by host driver to transmit data to SDIO controller, which will be updated to H2DRM1R and read by FW. |

|       |                |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------|----------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| e     |                |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | RO             |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0              | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Bit   | 15             | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name  | <b>D2H_RMo</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | RO             |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0              | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| Bit(s) | Name    | Description                                                                                                                                                                                        |
|--------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | D2H_RMo | This register is used by host driver to receive data from SDIO controller, which is updated through D2HSMoR by FW.<br>The property of RO/ RC is by control of WHCR.<br>RECV_MAILBOX_RD_CLR_EN bit. |

**00000007C D2HRM1R                          Device to Host Receive Mailbox 1 Register                          000000000**

|       |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31             | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  | <b>D2H_RM1</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0              | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15             | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>D2H_RM1</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0              | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name    | Description                                                                                                                                                                                        |
|--------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | D2H_RM1 | This register is used by host driver to receive data from SDIO controller, which is updated through D2HSM1R by FW.<br>The property of RO/ RC is by control of WHCR.<br>RECV_MAILBOX_RD_CLR_EN bit. |

**00000080 D2HRM2R                          Device to Host Receive Mailbox 2 Register                          000000000**

|       |                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31             | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  | <b>D2H_RM2</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0              | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15             | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>D2H_RM2</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0              | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | D2H_RM2 | <p>This register is used by host driver to receive data from SDIO controller, which is updated through D2HSM2R by FW. For synchronization of hardware, it is recommended to read this register more than once to give more host clock cycles to device to get the latest result, especially for EHPI interface.</p> <p>Note that this register could be read when there is no AHB clock, i.e. host driver could get this message when chip is in low power mode.</p> |

| <b>00000090 WRPLR WLAN RX Packet Length Register 00000000</b> |                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|---------------------------------------------------------------|-------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit                                                           | 31                | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b>                                                   | RX1_PACKET_LENGTH |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                                                   | RO                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Rese t</b>                                                 | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |    |
| <b>Bit</b>                                                    | 15                | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>                                                   | RX0_PACKET_LENGTH |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                                                   | RO                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Rese t</b>                                                 | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |    |

| Bit(s) | Name              | Description                                                                                                                                                                                                                                                    |
|--------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16  | RX1_PACKET_LENGTH | <p>This register is used to get the next RX packet length in the RX1 length FIFO, which is updated by FW HWRQ1CR. When this field is read, it will report only 1 RX packet length in this RX queue, and at most 1 packet will return by next RX port read.</p> |
| 15:0   | RX0_PACKET_LENGTH | <p>This register is used to get the next RX packet length in the RX0 length FIFO, which is updated by FW HWRQoCR. When this field is read, it will report only 1 RX packet length in this RX queue, and at most 1 packet will return by next RX port read.</p> |

| <b>00000094 WRPLR1 WLAN RX Packet Length Register 1 00000000</b> |                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------------------------------------------------------------------|-------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit                                                              | 31                | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b>                                                      | RX3_PACKET_LENGTH |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                                                      | RO                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Rese t</b>                                                    | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |    |
| <b>Bit</b>                                                       | 15                | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>                                                      | RX2_PACKET_LENGTH |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                                                      | RO                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Rese t</b>                                                    | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |    |

| Bit(s) | Name              | Description                                                                                                                                                                                                                                                    |
|--------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16  | RX3_PACKET_LENGTH | <p>This register is used to get the next RX packet length in the RX3 length FIFO, which is updated by FW HWRQ3CR. When this field is read, it will report only 1 RX packet length in this RX queue, and at most 1 packet will return by next RX port read.</p> |
| 15:0   | RX2_PACKET_LENGTH | <p>This register is used to get the next RX packet length in the RX2 length FIFO, which is updated by FW HWRQ2CR.</p>                                                                                                                                          |

| Bit(s) | Name | Description                                                                                                                              |
|--------|------|------------------------------------------------------------------------------------------------------------------------------------------|
|        |      | When this field is read, it will report only 1 RX packet length in this RX queue, and at most 1 packet will return by next RX port read. |

| <b>00000098 WRPLR2 Reserve for WRPLR2 00000000</b> |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----------------------------------------------------|--------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit                                                | 31                 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name                                               | <b>RESV_WRPLR2</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                                               | RO                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t                                             | 0                  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |    |
| Bit                                                | 15                 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name                                               | <b>RESV_WRPLR2</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                                               | RO                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t                                             | 0                  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |    |

| Bit(s) | Name        | Description |
|--------|-------------|-------------|
| 31:0   | RESV_WRPLR2 | RESV_WRPLR2 |

| <b>0000009C WRPLR3 Reserve for WRPLR3 00000000</b> |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----------------------------------------------------|--------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit                                                | 31                 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name                                               | <b>RESV_WRPLR3</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                                               | RO                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t                                             | 0                  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |    |
| Bit                                                | 15                 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name                                               | <b>RESV_WRPLR3</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                                               | RO                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t                                             | 0                  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |    |

| Bit(s) | Name        | Description |
|--------|-------------|-------------|
| 31:0   | RESV_WRPLR3 | RESV_WRPLR3 |

| <b>000000A0 EHTCR EHPI transaction count register (EHPI only) 00000004</b> |                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----------------------------------------------------------------------------|---------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit                                                                        | 31                        | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name                                                                       | <b>EHPI_TRANS_CNT_REG</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                                                                       | RW                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t                                                                     | 0                         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |    |
| Bit                                                                        | 15                        | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name                                                                       | <b>EHPI_TRANS_CNT_REG</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                                                                       | RW                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t                                                                     | 0                         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  |    |

| Bit(s) | Name               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|--------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | EHPI_TRANS_CNT_REG | This register is used for SDIO controller to know the transaction boundary of EHPI burst access. For normal registers, it is limited to access them in 4B boundary. For data port access (WTDR0, WTDR1, WRDR0 and WRDR1 etc.) and WHISR enhanced access, the length can be more than 4B, Hence, host needs set it before it access these register and SDIO controller would take this length as transaction length. The transaction count should be set with 4B alignment |

| <b>000000AC WOLTCR</b> |    |    |    |    |    |    |    |                      |    |    |    |                                                      |                                                      |                                                       | <b>On Line-Tuning Control Register</b>               |                                                |   |   |   | <b>00000000</b> |   |   |   |  |
|------------------------|----|----|----|----|----|----|----|----------------------|----|----|----|------------------------------------------------------|------------------------------------------------------|-------------------------------------------------------|------------------------------------------------------|------------------------------------------------|---|---|---|-----------------|---|---|---|--|
| Bit                    | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24                   | 23 | 22 | 21 | 20                                                   | 19                                                   | 18                                                    | 17                                                   | 16                                             |   |   |   |                 |   |   |   |  |
| Name                   |    |    |    |    |    |    |    |                      |    |    |    | DA<br>T3<br>_O<br>_UT<br>_O<br>_F<br>_BO<br>_UN<br>D | DA<br>T2<br>_O<br>_UT<br>_O<br>_F<br>_BO<br>_UN<br>D | DA<br>T1<br>_OU<br>_T<br>_OF<br>_B<br>_BO<br>_UN<br>D | DA<br>To<br>_O<br>_UT<br>_O<br>_F<br>_BO<br>_UN<br>D | CM<br>D<br>_OU<br>_T<br>_OF<br>_B<br>_OU<br>ND |   |   |   |                 |   |   |   |  |
| Type                   |    |    |    |    |    |    |    |                      |    |    |    | W1<br>C                                              | W1<br>C                                              | W1<br>C                                               | W1<br>C                                              | W1<br>C                                        |   |   |   |                 |   |   |   |  |
| Reset                  |    |    |    |    |    |    |    |                      |    |    |    | o                                                    | o                                                    | o                                                     | o                                                    | o                                              |   |   |   |                 |   |   |   |  |
| Bit                    | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8                    | 7  | 6  | 5  | 4                                                    | 3                                                    | 2                                                     | 1                                                    | 0                                              |   |   |   |                 |   |   |   |  |
| Name                   |    |    |    |    |    |    |    | TR<br>AI<br>N<br>_EN |    |    |    | <b>TRAIN_WINDOW</b>                                  |                                                      |                                                       |                                                      |                                                |   |   |   |                 |   |   |   |  |
| Type                   |    |    |    |    |    |    |    | RW                   |    |    |    | <b>RW</b>                                            |                                                      |                                                       |                                                      |                                                |   |   |   |                 |   |   |   |  |
| Reset                  |    |    |    |    |    |    |    | o                    |    |    |    | o                                                    | o                                                    | o                                                     | o                                                    | o                                              | o | o | o | o               | o | o | o |  |

| Bit(s) | Name              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|--------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 20     | DAT3_OUT_OF_BOUND | <b>This field is to notice host driver that the train window of data 3 is out of available delay gears.</b><br>The boundary of delay gears would be 0 and 31. If the applied training window out of the bound then this field would be asserted. Host driver can read these fields to know if any delay training is out of boundary. Also, the host driver can write 1 to this field to clear the status. This field is primary for no training window indication. |
| 19     | DAT2_OUT_OF_BOUND | <b>This field is to notice host driver that the train window of data 2 is out of available delay gears.</b><br>The boundary of delay gears would be 0 and 31. If the applied training window out of the bound then this field would be asserted. Host driver can read these fields to know if any delay training is out of boundary. Also, the host driver can write 1 to this field to clear the status. This field is primary for no training window indication. |
| 18     | DAT1_OUT_OF_BOUND | <b>This field is to notice host driver that the train window of data 1 is out of available delay gears.</b><br>The boundary of delay gears would be 0 and 31. If the applied training window out of the bound then this field would be asserted. Host driver can read these fields to know if any delay training is out of boundary. Also, the host driver can write 1 to this field to clear the status. This field is primary for no training window indication. |
| 17     | DATO_OUT_OF_BOUND | <b>This field is to notice host driver that the train window of data 0 is out of available delay gears.</b><br>The boundary of delay gears would be 0 and 31. If the applied training window out of the bound then this field would be asserted. Host driver can read these fields to know if any delay training is out                                                                                                                                            |

| <b>Bit(s)</b> | <b>Name</b>      | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---------------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16            | CMD_OUT_OF_BOUND | <p>of boundary. Also, the host driver can write 1 to this field to clear the status. This field is primary for no training window indication.</p> <p><b>This field is to notice host driver that the train window of command is out of available delay gears.</b></p> <p>The boundary of delay gears would be 0 and 31. If the applied training window out of the bound then this field would be asserted. Host driver can read these fields to know if any delay training is out of boundary. Also, the host driver can write 1 to this field to clear the status. This field is primary for no training window indication.</p> |
| 8             | TRAIN_EN         | <p><b>Host driver can set this field to enable SDIO on-line tuning function.</b></p> <p>This field is about SDIO on-line tuning function implying that hardware could automatically tune the delay training gear to know the surrounding delay gears are safe or not.</p>                                                                                                                                                                                                                                                                                                                                                        |
| 5:0           | TRAIN_WINDOW     | <p><b>Host driver can set this field to set the training window size which decides how many gears would be involved.</b></p> <p>This field is about SDIO on-line tuning function implying that hardware could automatically tune the delay training gear for test. The total delay gears for one data bus are 32. So the maximal training window size would be 32. For example, if the current delay gear is 15 and the train window is set to 5. When the on-line delay training is enabled, the five-time training delay gears would be 13, 14, 15, 16, and 17.</p>                                                            |

| <b>Bit(s)</b> | <b>Name</b>         | <b>Description</b>                                                                                                                                                                                                                               |
|---------------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0          | TEST_MODE_DATA_PORT | <p><b>For Test Mode Read / Write.</b></p> <p>According to the configuration of WTMCR[1:0]:</p> <ul style="list-style-type: none"> <li>-64-bits configurable data register</li> <li>-32-bits configurable data register</li> <li>-PRBS</li> </ul> |

| 000000B4 WTMCR |    | Test Mode Control Register |    |    |    |    |    |                                                                                     |               |    |    |    |    |    |    | 00080000 |   |  |  |  |  |  |
|----------------|----|----------------------------|----|----|----|----|----|-------------------------------------------------------------------------------------|---------------|----|----|----|----|----|----|----------|---|--|--|--|--|--|
| Bit            | 31 | 30                         | 29 | 28 | 27 | 26 | 25 | 24                                                                                  | 23            | 22 | 21 | 20 | 19 | 18 | 17 | 16       |   |  |  |  |  |  |
| Name           |    |                            |    |    |    |    |    | TE<br>ST<br><u>M</u><br><u>OD</u><br><u>E</u><br><u>FW</u><br><u>O</u><br><u>WN</u> | PRBS_INIT_VAL |    |    |    |    |    |    |          |   |  |  |  |  |  |
| Type           |    |                            |    |    |    |    |    | RO                                                                                  | RW            |    |    |    |    |    |    |          |   |  |  |  |  |  |
| Rese           |    |                            |    |    |    |    |    | 0                                                                                   | 0             | 0  | 0  | 0  | 1  | 0  | 0  | 0        | 0 |  |  |  |  |  |

| t      |    |    |    |    |    |    |   |                                            |   |   |   |   |   |   |   |                  |  |
|--------|----|----|----|----|----|----|---|--------------------------------------------|---|---|---|---|---|---|---|------------------|--|
| Bit    | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8                                          | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                |  |
| Name   |    |    |    |    |    |    |   | TE<br>ST<br>M<br>OD<br>E<br>ST<br>AT<br>US |   |   |   |   |   |   |   | TEST_MODE_SELECT |  |
| Type   |    |    |    |    |    |    |   | RO                                         |   |   |   |   |   |   |   | RW               |  |
| Rese t |    |    |    |    |    |    |   | o                                          |   |   |   |   |   |   | o | o                |  |

| Bit(s) | Name             | Description                                                                                                                                                                                                                                        |
|--------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24     | TEST_MODE_FW_OWN | Indicate the ownership of Test Mode Control Register : WTMCR,WTMDPCRo,WTMDPCR1<br>0: Host has the ownership<br>1: FirmWare has the ownership                                                                                                       |
| 23:16  | PRBS_INIT_VAL    | Initial Value For PRBS Generator                                                                                                                                                                                                                   |
| 8      | TEST_MODE_STATUS | To Record the compare result of latest Test Mode write , It is read only for Host and Firmware.<br>0: Data compare of Test Mode write is Pass<br>1: Data compare of Test Mode write is Fail                                                        |
| 1:0    | TEST_MODE_SELECT | Select the test mode data pattern<br>-64-bits configurable data register (WTMDPCRo:WTMDPCR1)<br>-32-bits configurable data register -PRBS<br>00: the 32bit data pattern<br>01: the 64bit data pattern<br>10: the PRBS data pattern<br>11: reserved |

**ooooooooB8 WTMDPCRo****Test Mode Data Pattern Control Register 0**

FoFoFoFo

| Bit    | 31                       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------|--------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name   | TEST_MODE_DATA_PATTERN_0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type   | RW                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t | 1                        | 1  | 1  | 1  | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | 0  | 0  | 0  | 0  |
| Bit    | 15                       | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name   | TEST_MODE_DATA_PATTERN_0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type   | RW                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Rese t | 1                        | 1  | 1  | 1  | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | 0  | 0  | 0  | 0  |

**Bit(s)****Description**

31:0 TEST\_MODE\_DATA\_PATTERN\_0 Data pattern for Test Mode read

**ooooooooBC WTMDPCR1****Test Mode Data Pattern Control Register 1**

FoFoFoFo

| Bit  | 31                       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|--------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name | TEST_MODE_DATA_PATTERN_1 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

|              |                          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|--------------|--------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>e</b>     |                          |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>  | RW                       |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Reset</b> | 1                        | 1  | 1  | 1  | 0  | 0  | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 |
| <b>Bit</b>   | 15                       | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| <b>Name</b>  | TEST_MODE_DATA_PATTERN_1 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Type</b>  | RW                       |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Reset</b> | 1                        | 1  | 1  | 1  | 0  | 0  | 0 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 | 0 |

| <b>Bit(s)</b> | <b>Name</b>              | <b>Description</b>               |
|---------------|--------------------------|----------------------------------|
| 31:0          | TEST_MODE_DATA_PATTERN_1 | Data pattern for Test Mode write |

|                 |               |                                        |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-----------------|---------------|----------------------------------------|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>000000Co</b> | <b>FWDLDR</b> | <b>Firmware Download Data Register</b> | <b>00000000</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Bit</b>      | 31            | 30                                     | 29              | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b>     | FWDL_DATA     |                                        |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>     | WO            |                                        |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>    | 0             | 0                                      | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>      | 15            | 14                                     | 13              | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>     | FWDL_DATA     |                                        |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>     | WO            |                                        |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>    | 0             | 0                                      | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0          | FWDL_DATA   | <p>This register is used by host to send SDIO controller TX_HEADER with firmware scatter to specified destination address.</p> <p>The first DW of the TX data is treated as HIF TX header, which shares the same format with TX packet format. SDIO controller would transmit these data to the destination address starting from FWDLDSAR in turn. Host could aggregate multiple transmission data packets in one transaction. Note that it is not allowed to cut data packet in different transactions as normal TX case.</p> <p>For firmware download, host could access this register without driver own = 1, but be sure that system AHB clock for SDIO controller, AHB bus and destination memory is on by using FWDLCMR0 and FWDLCMR1 first.</p> |

|                 |                         |                                                                |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-----------------|-------------------------|----------------------------------------------------------------|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>000000C4</b> | <b>FWDLDSAR</b>         | <b>Firmware Download Destination Starting Address Register</b> | <b>00000000</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Bit</b>      | 31                      | 30                                                             | 29              | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b>     | FWDL_DEST_STARTING_ADDR |                                                                |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>     | RW                      |                                                                |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>    | 0                       | 0                                                              | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>      | 15                      | 14                                                             | 13              | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>     | FWDL_DEST_STARTING_ADDR |                                                                |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>     | RW                      |                                                                |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>    | 0                       | 0                                                              | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) Name                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0 FWDL_DEST_STARTING_ADDR | <p><b>This register is used by host to specify firmware download destination starting address. Note that it should be 4B-align address.</b></p> <p>Destination address is automatically increased after TX data has been written to AHB, and could be read back by host software for reference. It would be updated by per-packet based.</p> <p>For firmware download, host could access this register without driver own = 1, but be sure that system AHB clock for SDIO controller, AHB bus and destination memory is on by using FWDLCMR0 and FWDLCMR1 first.</p> |

| Bit(s) | Name      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8      | FWDL_RDY  | <b>Host driver needs to check if this bit is 1 to set new FWDLDSAR for firmware download of new segment. Then it could write firmware content to SDIO controller.</b><br><br>0 : It is NOT ready to write firmware from host to SDIO controller.<br>1 : It is ready to write firmware from host to SDIO controller.                                                                                                                                                                                                                                               |
| 0      | FWDL_MODE | <b>For firmware download, host could access this register without driver own = 1, but be sure that system AHB clock for SDIO controller, AHB bus and destination memory is on by using FWDLCMR0 and FWDLCMR1 first. Then host driver can turn on this bit to switch to firmware download mode to execute firmware download. Note that the normal TX/RX path can't work in this mode, host driver have to turn off this mode after firmware download procedure is done.</b><br><br>0 : Firmware download mode is disabled<br>1 : Firmware download mode is enabled |

| e      |                                 |                                 |                                 |                                 |                                 |                                 |                                 |                                 |                                 |                                 |                                 |                                 |                                 |                                 |                                 |   |
|--------|---------------------------------|---------------------------------|---------------------------------|---------------------------------|---------------------------------|---------------------------------|---------------------------------|---------------------------------|---------------------------------|---------------------------------|---------------------------------|---------------------------------|---------------------------------|---------------------------------|---------------------------------|---|
| Type   |                                 |                                 |                                 |                                 |                                 |                                 |                                 |                                 |                                 |                                 |                                 |                                 |                                 |                                 |                                 |   |
| Rese t |                                 |                                 |                                 |                                 |                                 |                                 |                                 |                                 |                                 |                                 |                                 |                                 |                                 |                                 |                                 |   |
| Bit    | 15                              | 14                              | 13                              | 12                              | 11                              | 10                              | 9                               | 8                               | 7                               | 6                               | 5                               | 4                               | 3                               | 2                               | 1                               | 0 |
| Name   | FW<br>DL<br>C<br>MR<br>O_1<br>5 | FW<br>DL<br>C<br>MR<br>O_1<br>4 | FW<br>DL<br>C<br>MR<br>O_1<br>3 | FW<br>DL<br>C<br>MR<br>O_1<br>2 | FW<br>DL<br>C<br>MR<br>O_1<br>1 | FW<br>DL<br>C<br>MR<br>O_0<br>9 | FW<br>DL<br>C<br>MR<br>O_8<br>7 | FW<br>DL<br>C<br>MR<br>O_6<br>8 | FW<br>DL<br>C<br>MR<br>O_5<br>6 | FW<br>DL<br>C<br>MR<br>O_4<br>5 | FW<br>DL<br>C<br>MR<br>O_3<br>4 | FW<br>DL<br>C<br>MR<br>O_2<br>3 | FW<br>DL<br>C<br>MR<br>O_1<br>2 | FW<br>DL<br>C<br>MR<br>O_0<br>1 | FW<br>DL<br>C<br>MR<br>O_0<br>0 |   |
| Type   | RO                              |   |
| Rese t | 0                               | 0                               | 0                               | 0                               | 0                               | 0                               | 0                               | 0                               | 0                               | 0                               | 0                               | 0                               | 0                               | 0                               | 0                               |   |

| Bit(s) | Name         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15     | FWDL_CMRO_15 | <b>Function of this register is user-defined and is used in firmware download stage.</b><br>When there no system AHB clock after power-on and host driver has not got driver own. It could set this register to notice HW and could also read this register from HW.<br>For example, host driver could set some register to request clock controller to turn on AHB clock of system bus and memory storage. And it could be read if the platform state is in sleep state, firmware download state or fully operation state. The meaning of these bits are all defined by customer, it is transparent to SDIO controller. |
| 14     | FWDL_CMRO_14 | <b>Function of this register is user-defined and is used in firmware download stage.</b><br>When there no system AHB clock after power-on and host driver has not got driver own. It could set this register to notice HW and could also read this register from HW.<br>For example, host driver could set some register to request clock controller to turn on AHB clock of system bus and memory storage. And it could be read if the platform state is in sleep state, firmware download state or fully operation state. The meaning of these bits are all defined by customer, it is transparent to SDIO controller. |
| 13     | FWDL_CMRO_13 | <b>Function of this register is user-defined and is used in firmware download stage.</b><br>When there no system AHB clock after power-on and host driver has not got driver own. It could set this register to notice HW and could also read this register from HW.<br>For example, host driver could set some register to request clock controller to turn on AHB clock of system bus and memory storage. And it could be read if the platform state is in sleep state, firmware download state or fully operation state. The meaning of these bits are all defined by customer, it is transparent to SDIO controller. |
| 12     | FWDL_CMRO_12 | <b>Function of this register is user-defined and is used in firmware download stage.</b><br>When there no system AHB clock after power-on and host driver has not got driver own. It could set this register to notice HW and could also read this register from HW.<br>For example, host driver could set some register to request clock controller to turn on AHB clock of system bus and memory storage. And it could be read if the platform state is in sleep state, firmware download state or fully operation state. The meaning of these bits are all defined by customer, it is transparent to SDIO controller. |
| 11     | FWDL_CMRO_11 | <b>Function of this register is user-defined and is used in firmware download stage.</b><br>When there no system AHB clock after power-on and host driver has not got driver own. It could set this register to notice HW and could also read this register from HW.<br>For example, host driver could set some register to request clock controller to turn on AHB clock of system bus and memory storage.                                                                                                                                                                                                              |

| Bit(s) | Name         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10     | FWDL_CMRo_10 | <p>And it could be read if the platform state is in sleep state, firmware download state or fully operation state. The meaning of these bits are all defined by customer, it is transparent to SDIO controller.</p> <p><b>Function of this register is user-defined and is used in firmware download stage.</b></p>                                                                                                                                                                                                                                                                                                                     |
| 9      | FWDL_CMRo_9  | <p>When there no system AHB clock after power-on and host driver has not got driver own. It could set this register to notice HW and could also read this register from HW.</p> <p>For example, host driver could set some register to request clock controller to turn on AHB clock of system bus and memory storage. And it could be read if the platform state is in sleep state, firmware download state or fully operation state. The meaning of these bits are all defined by customer, it is transparent to SDIO controller.</p> <p><b>Function of this register is user-defined and is used in firmware download stage.</b></p> |
| 8      | FWDL_CMRo_8  | <p>When there no system AHB clock after power-on and host driver has not got driver own. It could set this register to notice HW and could also read this register from HW.</p> <p>For example, host driver could set some register to request clock controller to turn on AHB clock of system bus and memory storage. And it could be read if the platform state is in sleep state, firmware download state or fully operation state. The meaning of these bits are all defined by customer, it is transparent to SDIO controller.</p> <p><b>Function of this register is user-defined and is used in firmware download stage.</b></p> |
| 7      | FWDL_CMRo_7  | <p>When there no system AHB clock after power-on and host driver has not got driver own. It could set this register to notice HW and could also read this register from HW.</p> <p>For example, host driver could set some register to request clock controller to turn on AHB clock of system bus and memory storage. And it could be read if the platform state is in sleep state, firmware download state or fully operation state. The meaning of these bits are all defined by customer, it is transparent to SDIO controller.</p> <p><b>Function of this register is user-defined and is used in firmware download stage.</b></p> |
| 6      | FWDL_CMRo_6  | <p>When there no system AHB clock after power-on and host driver has not got driver own. It could set this register to notice HW and could also read this register from HW.</p> <p>For example, host driver could set some register to request clock controller to turn on AHB clock of system bus and memory storage. And it could be read if the platform state is in sleep state, firmware download state or fully operation state. The meaning of these bits are all defined by customer, it is transparent to SDIO controller.</p> <p><b>Function of this register is user-defined and is used in firmware download stage.</b></p> |
| 5      | FWDL_CMRo_5  | <p>When there no system AHB clock after power-on and host driver has not got driver own. It could set this register to notice HW and could also read this register from HW.</p> <p>For example, host driver could set some register to request clock controller to turn on AHB clock of system bus and memory storage. And it could be read if the platform state is in sleep state, firmware download state or fully operation state. The meaning of these bits are all defined by customer, it is transparent to SDIO controller.</p> <p><b>Function of this register is user-defined and is used in firmware download stage.</b></p> |
|        |              | <p>When there no system AHB clock after power-on and host driver has not got driver own. It could set this register to notice HW and could also read this register from HW.</p> <p>For example, host driver could set some register to request clock controller to turn on AHB clock of system bus and memory storage. And it could be read if the platform state is in sleep state, firmware download state or fully operation state. The meaning of these bits are all defined by customer, it is transparent to SDIO controller.</p>                                                                                                 |

| Bit(s) | Name        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4      | FWDL_CMRo_4 | <p><b>Function of this register is user-defined and is used in firmware download stage.</b></p> <p>When there no system AHB clock after power-on and host driver has not got driver own. It could set this register to notice HW and could also read this register from HW.</p> <p>For example, host driver could set some register to request clock controller to turn on AHB clock of system bus and memory storage. And it could be read if the platform state is in sleep state, firmware download state or fully operation state. The meaning of these bits are all defined by customer, it is transparent to SDIO controller.</p> |
| 3      | FWDL_CMRo_3 | <p><b>Function of this register is user-defined and is used in firmware download stage.</b></p> <p>When there no system AHB clock after power-on and host driver has not got driver own. It could set this register to notice HW and could also read this register from HW.</p> <p>For example, host driver could set some register to request clock controller to turn on AHB clock of system bus and memory storage. And it could be read if the platform state is in sleep state, firmware download state or fully operation state. The meaning of these bits are all defined by customer, it is transparent to SDIO controller.</p> |
| 2      | FWDL_CMRo_2 | <p><b>Function of this register is user-defined and is used in firmware download stage.</b></p> <p>When there no system AHB clock after power-on and host driver has not got driver own. It could set this register to notice HW and could also read this register from HW.</p> <p>For example, host driver could set some register to request clock controller to turn on AHB clock of system bus and memory storage. And it could be read if the platform state is in sleep state, firmware download state or fully operation state. The meaning of these bits are all defined by customer, it is transparent to SDIO controller.</p> |
| 1      | FWDL_CMRo_1 | <p><b>Function of this register is user-defined and is used in firmware download stage.</b></p> <p>When there no system AHB clock after power-on and host driver has not got driver own. It could set this register to notice HW and could also read this register from HW.</p> <p>For example, host driver could set some register to request clock controller to turn on AHB clock of system bus and memory storage. And it could be read if the platform state is in sleep state, firmware download state or fully operation state. The meaning of these bits are all defined by customer, it is transparent to SDIO controller.</p> |
| 0      | FWDL_CMRo_0 | <p><b>Function of this register is user-defined and is used in firmware download stage.</b></p> <p>When there no system AHB clock after power-on and host driver has not got driver own. It could set this register to notice HW and could also read this register from HW.</p> <p>For example, host driver could set some register to request clock controller to turn on AHB clock of system bus and memory storage. And it could be read if the platform state is in sleep state, firmware download state or fully operation state. The meaning of these bits are all defined by customer, it is transparent to SDIO controller.</p> |

**ooooooooDo FWDLCMR1****Firmware Download Customized Register 1****oooooooo**

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |

| Name  | FW<br>DL<br>_C<br>MR<br><b>1_1</b><br><b>5</b> | FW<br>DL<br>_C<br>MR<br><b>1_1</b><br><b>4</b> | FW<br>DL<br>_C<br>MR<br><b>1_1</b><br><b>3</b> | FW<br>DL<br>_C<br>MR<br><b>1_1</b><br><b>2</b> | FW<br>DL<br>_C<br>MR<br><b>1_1</b><br><b>1</b> | FW<br>DL<br>_C<br>MR<br><b>1_1</b><br><b>0</b> | FW<br>DL<br>_C<br>MR<br><b>1_9</b> | FW<br>DL<br>_C<br>MR<br><b>1_8</b> | FW<br>DL<br>_C<br>MR<br><b>1_7</b> | FW<br>DL<br>_C<br>MR<br><b>1_6</b> | FW<br>DL<br>_C<br>MR<br><b>1_5</b> | FW<br>DL<br>_C<br>MR<br><b>1_4</b> | FW<br>DL<br>_C<br>MR<br><b>1_3</b> | FW<br>DL<br>_C<br>MR<br><b>1_2</b> | FW<br>DL<br>_C<br>MR<br><b>1_1</b> | FW<br>DL<br>_C<br>MR<br><b>1_0</b> |
|-------|------------------------------------------------|------------------------------------------------|------------------------------------------------|------------------------------------------------|------------------------------------------------|------------------------------------------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------|------------------------------------|
| Type  | RO                                             | RO                                             | RO                                             | RO                                             | RO                                             | RO                                             | RO                                 | RO                                 | RO                                 | RO                                 | RO                                 | RO                                 | RO                                 | RO                                 | RO                                 | RO                                 |
| Reset | 0                                              | 0                                              | 0                                              | 0                                              | 0                                              | 0                                              | 0                                  | 0                                  | 0                                  | 0                                  | 0                                  | 0                                  | 0                                  | 0                                  | 0                                  | 0                                  |

| Bit(s) | Name         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15     | FWDL_CMR1_15 | <b>Function of this register is user-defined and is used in firmware download stage.</b><br>When there no system AHB clock after power-on and host driver has not got driver own. It could set this register to notice HW and could also read this register from HW.<br>For example, host driver could set some register to request clock controller to turn on AHB clock of system bus and memory storage. And it could be read if the platform state is in sleep state, firmware download state or fully operation state. The meaning of these bits are all defined by customer, it is transparent to SDIO controller. |
| 14     | FWDL_CMR1_14 | <b>Function of this register is user-defined and is used in firmware download stage.</b><br>When there no system AHB clock after power-on and host driver has not got driver own. It could set this register to notice HW and could also read this register from HW.<br>For example, host driver could set some register to request clock controller to turn on AHB clock of system bus and memory storage. And it could be read if the platform state is in sleep state, firmware download state or fully operation state. The meaning of these bits are all defined by customer, it is transparent to SDIO controller. |
| 13     | FWDL_CMR1_13 | <b>Function of this register is user-defined and is used in firmware download stage.</b><br>When there no system AHB clock after power-on and host driver has not got driver own. It could set this register to notice HW and could also read this register from HW.<br>For example, host driver could set some register to request clock controller to turn on AHB clock of system bus and memory storage. And it could be read if the platform state is in sleep state, firmware download state or fully operation state. The meaning of these bits are all defined by customer, it is transparent to SDIO controller. |
| 12     | FWDL_CMR1_12 | <b>Function of this register is user-defined and is used in firmware download stage.</b><br>When there no system AHB clock after power-on and host driver has not got driver own. It could set this register to notice HW and could also read this register from HW.<br>For example, host driver could set some register to request clock controller to turn on AHB clock of system bus and memory storage. And it could be read if the platform state is in sleep state, firmware download state or fully operation state. The meaning of these bits are all defined by customer, it is transparent to SDIO controller. |
| 11     | FWDL_CMR1_11 | <b>Function of this register is user-defined and is used in firmware download stage.</b><br>When there no system AHB clock after power-on and host driver has not got driver own. It could set this register to notice HW and could also read this register from HW.<br>For example, host driver could set some register to request clock controller to turn on AHB clock of system bus and memory storage. And it could be read if the platform state is in sleep state, firmware download state or fully operation state. The meaning of these bits are all defined by customer, it is transparent to SDIO controller. |
| 10     | FWDL_CMR1_10 | <b>Function of this register is user-defined and is used in firmware download stage.</b><br>When there no system AHB clock after power-on and host driver                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

| Bit(s) | Name        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9      | FWDL_CMRI_9 | <p>has not got driver own. It could set this register to notice HW and could also read this register from HW.<br/> For example, host driver could set some register to request clock controller to turn on AHB clock of system bus and memory storage. And it could be read if the platform state is in sleep state, firmware download state or fully operation state. The meaning of these bits are all defined by customer, it is transparent to SDIO controller.</p> <p><b>Function of this register is user-defined and is used in firmware download stage.</b></p> <p>When there no system AHB clock after power-on and host driver has not got driver own. It could set this register to notice HW and could also read this register from HW.</p> |
| 8      | FWDL_CMRI_8 | <p>For example, host driver could set some register to request clock controller to turn on AHB clock of system bus and memory storage. And it could be read if the platform state is in sleep state, firmware download state or fully operation state. The meaning of these bits are all defined by customer, it is transparent to SDIO controller.</p> <p><b>Function of this register is user-defined and is used in firmware download stage.</b></p> <p>When there no system AHB clock after power-on and host driver has not got driver own. It could set this register to notice HW and could also read this register from HW.</p>                                                                                                                 |
| 7      | FWDL_CMRI_7 | <p>For example, host driver could set some register to request clock controller to turn on AHB clock of system bus and memory storage. And it could be read if the platform state is in sleep state, firmware download state or fully operation state. The meaning of these bits are all defined by customer, it is transparent to SDIO controller.</p> <p><b>Function of this register is user-defined and is used in firmware download stage.</b></p> <p>When there no system AHB clock after power-on and host driver has not got driver own. It could set this register to notice HW and could also read this register from HW.</p>                                                                                                                 |
| 6      | FWDL_CMRI_6 | <p>For example, host driver could set some register to request clock controller to turn on AHB clock of system bus and memory storage. And it could be read if the platform state is in sleep state, firmware download state or fully operation state. The meaning of these bits are all defined by customer, it is transparent to SDIO controller.</p> <p><b>Function of this register is user-defined and is used in firmware download stage.</b></p> <p>When there no system AHB clock after power-on and host driver has not got driver own. It could set this register to notice HW and could also read this register from HW.</p>                                                                                                                 |
| 5      | FWDL_CMRI_5 | <p>For example, host driver could set some register to request clock controller to turn on AHB clock of system bus and memory storage. And it could be read if the platform state is in sleep state, firmware download state or fully operation state. The meaning of these bits are all defined by customer, it is transparent to SDIO controller.</p> <p><b>Function of this register is user-defined and is used in firmware download stage.</b></p> <p>When there no system AHB clock after power-on and host driver has not got driver own. It could set this register to notice HW and could also read this register from HW.</p>                                                                                                                 |
| 4      | FWDL_CMRI_4 | <p>For example, host driver could set some register to request clock controller to turn on AHB clock of system bus and memory storage. And it could be read if the platform state is in sleep state, firmware download state or fully operation state. The meaning of these bits are all defined by customer, it is transparent to SDIO controller.</p> <p><b>Function of this register is user-defined and is used in firmware download stage.</b></p> <p>When there no system AHB clock after power-on and host driver has not got driver own. It could set this register to notice HW and could also read this register from HW.</p>                                                                                                                 |
|        |             | <p>For example, host driver could set some register to request clock</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

| Bit(s) | Name        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3      | FWDL_CMR1_3 | <p>controller to turn on AHB clock of system bus and memory storage. And it could be read if the platform state is in sleep state, firmware download state or fully operation state. The meaning of these bits are all defined by customer, it is transparent to SDIO controller.</p> <p><b>Function of this register is user-defined and is used in firmware download stage.</b></p> <p>When there no system AHB clock after power-on and host driver has not got driver own. It could set this register to notice HW and could also read this register from HW.</p> <p>For example, host driver could set some register to request clock controller to turn on AHB clock of system bus and memory storage. And it could be read if the platform state is in sleep state, firmware download state or fully operation state. The meaning of these bits are all defined by customer, it is transparent to SDIO controller.</p> |
| 2      | FWDL_CMR1_2 | <p><b>Function of this register is user-defined and is used in firmware download stage.</b></p> <p>When there no system AHB clock after power-on and host driver has not got driver own. It could set this register to notice HW and could also read this register from HW.</p> <p>For example, host driver could set some register to request clock controller to turn on AHB clock of system bus and memory storage. And it could be read if the platform state is in sleep state, firmware download state or fully operation state. The meaning of these bits are all defined by customer, it is transparent to SDIO controller.</p>                                                                                                                                                                                                                                                                                       |
| 1      | FWDL_CMR1_1 | <p><b>Function of this register is user-defined and is used in firmware download stage.</b></p> <p>When there no system AHB clock after power-on and host driver has not got driver own. It could set this register to notice HW and could also read this register from HW.</p> <p>For example, host driver could set some register to request clock controller to turn on AHB clock of system bus and memory storage. And it could be read if the platform state is in sleep state, firmware download state or fully operation state. The meaning of these bits are all defined by customer, it is transparent to SDIO controller.</p>                                                                                                                                                                                                                                                                                       |
| 0      | FWDL_CMR1_0 | <p><b>Function of this register is user-defined and is used in firmware download stage.</b></p> <p>When there no system AHB clock after power-on and host driver has not got driver own. It could set this register to notice HW and could also read this register from HW.</p> <p>For example, host driver could set some register to request clock controller to turn on AHB clock of system bus and memory storage. And it could be read if the platform state is in sleep state, firmware download state or fully operation state. The meaning of these bits are all defined by customer, it is transparent to SDIO controller.</p>                                                                                                                                                                                                                                                                                       |

**ooooooooD4 WPLRCR**      **WLAN Packet Length Report Control Register**      **oooooooooooo**

| Bit   | 31 | 30 | 29              | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21              | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|-----------------|----|----|----|----|----|----|----|-----------------|----|----|----|----|----|
| Name  |    |    | RX3_RPT_PKT_LEN |    |    |    |    |    |    |    | RX2_RPT_PKT_LEN |    |    |    |    |    |
| Type  |    |    | RW              |    |    |    |    |    |    |    | RW              |    |    |    |    |    |
| Reset |    |    | 0               | 0  | 0  | 0  | 0  | 0  |    |    | 0               | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15 | 14 | 13              | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5               | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    | RX1_RPT_PKT_LEN |    |    |    |    |    |    |    | RXo_RPT_PKT_LEN |    |    |    |    |    |
| Type  |    |    | RW              |    |    |    |    |    |    |    | RW              |    |    |    |    |    |
| Reset |    |    | 0               | 0  | 0  | 0  | 0  | 0  |    |    | 0               | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29:24  | RX3_RPT_PKT_LEN | <p>If the RPT_OWN_RX_PACKET_LEN bit in WHCR is set, host driver can set this field to decide the maximal report length for RX queue 3 during enhance mode.</p> <p>If under the define of SDCTL_RX3_PACKET_LEN_64, The default value 0 is to report maximal packet number 64. Host driver can set the required length from 0 to 63.</p> <p>If under the define of SDCTL_RX3_PACKET_LEN_32, The default value 0 is to report maximal packet number 32. Host driver can set the required length from 0 to 31.</p> <p>If under the define of SDCTL_RX3_PACKET_LEN_16, The default value 0 is to report maximal packet number 16. Host driver can set the required length from 0 to 15.</p> <p>It is not allowed to set this field with the value larger than the maximal packet number.</p> |
| 21:16  | RX2_RPT_PKT_LEN | <p>If the RPT_OWN_RX_PACKET_LEN bit in WHCR is set, host driver can set this field to decide the maximal report length for RX queue 2 during enhance mode.</p> <p>If under the define of SDCTL_RX2_PACKET_LEN_64, The default value 0 is to report maximal packet number 64. Host driver can set the required length from 0 to 63.</p> <p>If under the define of SDCTL_RX2_PACKET_LEN_32, The default value 0 is to report maximal packet number 32. Host driver can set the required length from 0 to 31.</p> <p>If under the define of SDCTL_RX2_PACKET_LEN_16, The default value 0 is to report maximal packet number 16. Host driver can set the required length from 0 to 15.</p> <p>It is not allowed to set this field with the value larger than the maximal packet number.</p> |
| 13:8   | RX1_RPT_PKT_LEN | <p>If the RPT_OWN_RX_PACKET_LEN bit in WHCR is set, host driver can set this field to decide the maximal report length for RX queue 1 during enhance mode.</p> <p>If under the define of SDCTL_RXD_PACKET_LEN_64, The default value 0 is to report maximal packet number 64. Host driver can set the required length from 0 to 63.</p> <p>If under the define of SDCTL_RXD_PACKET_LEN_32, The default value 0 is to report maximal packet number 32. Host driver can set the required length from 0 to 31.</p> <p>If under the define of SDCTL_RXD_PACKET_LEN_16, The default value 0 is to report maximal packet number 16. Host driver can set the required length from 0 to 15.</p> <p>It is not allowed to set this field with the value larger than the maximal packet number.</p> |
| 5:0    | RX0_RPT_PKT_LEN | <p>If the RPT_OWN_RX_PACKET_LEN bit in WHCR is set, host driver can set this field to decide the maximal report length for RX queue 0 during enhance mode.</p> <p>If under the define of SDCTL_RXE_PACKET_LEN_64, The default value 0 is to report maximal packet number 64. Host driver can set the required length from 0 to 63.</p> <p>If under the define of SDCTL_RXE_PACKET_LEN_32, The default value 0 is to report maximal packet number 32. Host driver can set the required length from 0 to 31.</p> <p>If under the define of SDCTL_RXE_PACKET_LEN_16, The default value 0 is to report maximal packet number 16. Host driver can set the required length from 0 to 15.</p> <p>It is not allowed to set this field with the value larger than the maximal packet number.</p> |

| WLAN Snapshot Register |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit                    | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |

| Name  | SNAPSHOT |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------|----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Type  | RO       |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0        | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Bit   | 15       | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name  | SNAPSHOT |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | RO       |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0        | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| Bit(s) | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | SNAPSHOT | <p>A 32-bits register which could copy the content of AHB clock domain register being read.</p> <p>For register with RC property, If there is CRC Error during the read access, host driver shall keep reading this snapshot register until there is no CRC error to avoid information loss. SW should not go to read other register first, it is atomic operation.</p> <p>For register without RC property, If there is CRC Error during the read access, host could just read the original register again.</p> <p>Value in this register is undefined if previous read is reading register without RC property.</p> |

| 000000F8 VSCR Version Control Register 00000000 |            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------------------------------------------------|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit                                             | 31         | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name                                            | HW_VERSION |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                                            | RO         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset                                           | 0          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit                                             | 15         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name                                            | HW_VERSION |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                                            | RO         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset                                           | 0          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name       | Description               |
|--------|------------|---------------------------|
| 31:0   | HW_VERSION | Indicating the HW version |

| 000000FC WSDIOAICR Common SDIO Asynchronous Interrupt Control Register 00000004 |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|---------------------------------------------------------------------------------|--------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit                                                                             | 31                 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name                                                                            |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                                                                            |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset                                                                           |                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit                                                                             | 15                 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name                                                                            | SYNC_INT_CYCLE_NUM |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                                                                            | RW                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset                                                                           |                    |    |    |    |    |    |    |    |    |    |    |    | 0  | 1  | 0  | 0  |

| Bit(s) | Name               | Description                                                                                                                                                                                                                              |
|--------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0    | SYNC_INT_CYCLE_NUM | Control the sync. interrupt cycles before the asynchronous interrupt period. (4 cycle in default defined in SDIO spec. 3.0) This is for some specific host that could stop the SD clock before the defined asynchronous interrupt period |

| 00000100 CLKIOCR T28LP Clock Pad Macro IO Control Register 000A0422 |    |    |           |    |    |            |    |    |    |    |           |            |         |           |           |         |
|---------------------------------------------------------------------|----|----|-----------|----|----|------------|----|----|----|----|-----------|------------|---------|-----------|-----------|---------|
| Bit                                                                 | 31 | 30 | 29        | 28 | 27 | 26         | 25 | 24 | 23 | 22 | 21        | 20         | 19      | 18        | 17        | 16      |
| Name                                                                |    |    | CLK_RDSEL |    |    |            |    |    |    |    |           |            |         | CLK_TDSEL |           |         |
| Type                                                                |    |    | RW        |    |    |            |    |    |    |    |           |            |         | RW        |           |         |
| Reset                                                               |    |    | 0         | 0  | 0  | 0          | 0  | 0  |    |    |           |            | 1       | 0         | 1         | 0       |
| Bit                                                                 | 15 | 14 | 13        | 12 | 11 | 10         | 9  | 8  | 7  | 6  | 5         | 4          | 3       | 2         | 1         | 0       |
| Name                                                                |    |    |           |    |    | CLK_E8E4E2 |    |    |    |    | CL_K_SM_T | CL_K_PU_PD | CL_K_R1 | CL_K_R0   | CL_K_I_ES | CL_K_SR |
| Type                                                                |    |    |           |    |    | RW         |    |    |    |    | RW        | RW         | RW      | RW        | RW        | RW      |
| Reset                                                               |    |    |           |    |    | 1          | 0  | 0  |    |    | 1         | 0          | 0       | 0         | 1         | 0       |

| Bit(s) | Name       | Description                                                                                                                                                                                                                                                                                                                                                 |
|--------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29:24  | CLK_RDSEL  | <b>RX duty select</b><br>RDSEL[1:0]: Input buffer duty high when asserted (high pulse width adjustment)<br>RDSEL[3:2]: Input buffer duty low when asserted (low pulse width adjustment)<br>RDSEL[5:4]: Level shifter duty high when asserted (high pulse width adjustment)<br>RDSEL[7:6]: Level shifter duty low when asserted (low pulse width adjustment) |
| 19:16  | CLK_TDSEL  | <b>TX duty select</b><br>TDSEL[1:0]: Output level shifter duty high when asserted (high pulse width adjustment)<br>TDSEL[3:2]: Output level shifter duty low when asserted (low pulse width adjustment)                                                                                                                                                     |
| 10:8   | CLK_E8E4E2 | <b>TX Driving Strength Control.</b>                                                                                                                                                                                                                                                                                                                         |
| 5      | CLK_SMT    | <b>RX input buffer schmit trigger hysteresis control enable. High asserted.</b><br>SMT=1, Schmit Trigger enable                                                                                                                                                                                                                                             |
| 4      | CLK_PUPD   | <b>Pull-up / pull-down selection.</b><br>0: pull-up resistor<br>1: pull-down resistor<br>CLK pad default no pull                                                                                                                                                                                                                                            |
| 3      | CLK_R1     | <b>Select 50K resistor (0: not select, 1: select)</b>                                                                                                                                                                                                                                                                                                       |
| 2      | CLK_R0     | <b>Select 10K resistor (0: not select, 1: select)</b>                                                                                                                                                                                                                                                                                                       |
| 1      | CLK_IES    | <b>RX input buffer enable. High asserted.</b><br>Datapath: from IO to O. IES=0, O=0<br>According to IOCUP spec.<br>Power down mode, IES=0 must<br>Quiescent mode, IES=0 suggested                                                                                                                                                                           |
| 0      | CLK_SR     | <b>Output Slew Rate Control. High asserted.</b><br>SR=1, slower slew.<br>SR=0, no slew rate controlled.                                                                                                                                                                                                                                                     |

00000104 CMDIOCR T28LP

## Command Pad Macro IO Control Register

000A0422

| Bit   | 31 | 30 | 29               | 28                                     | 27 | 26                | 25 | 24 | 23 | 22 | 21                  | 20                   | 19               | 18             | 17              | 16             |
|-------|----|----|------------------|----------------------------------------|----|-------------------|----|----|----|----|---------------------|----------------------|------------------|----------------|-----------------|----------------|
| Name  |    |    | <b>CMD_RDSEL</b> |                                        |    |                   |    |    |    |    |                     |                      | <b>CMD_TDSEL</b> |                |                 |                |
| Type  |    |    | RW               |                                        |    |                   |    |    |    |    |                     |                      | RW               |                |                 |                |
| Reset |    |    | 0                | 0                                      | 0  | 0                 | 0  | 0  |    |    |                     |                      | 1                | 0              | 1               | 0              |
| Bit   | 15 | 14 | 13               | 12                                     | 11 | 10                | 9  | 8  | 7  | 6  | 5                   | 4                    | 3                | 2              | 1               | 0              |
| Name  |    |    |                  | RE<br>G_<br>CM<br>D_<br>SA<br>MP<br>LE |    | <b>CMD_E8E4E2</b> |    |    |    |    | CM<br>D_<br>SM<br>T | CM<br>D_<br>PU<br>PD | CM<br>D_<br>R1   | CM<br>D_<br>Ro | CM<br>D_<br>IES | CM<br>D_<br>SR |
| Type  |    |    |                  | RW                                     |    | RW                |    |    |    |    | RW                  | RW                   | RW               | RW             | RW              | RW             |
| Reset |    |    |                  | 0                                      |    | 1                 | 0  | 0  |    |    | 1                   | 0                    | 0                | 0              | 1               | 0              |

| Bit(s) | Name           | Description                                                                                                                                                                                                                                                                                                                                                 |
|--------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29:24  | CMD_RDSEL      | <b>RX duty select</b><br>RDSEL[1:0]: Input buffer duty high when asserted (high pulse width adjustment)<br>RDSEL[3:2]: Input buffer duty low when asserted (low pulse width adjustment)<br>RDSEL[5:4]: Level shifter duty high when asserted (high pulse width adjustment)<br>RDSEL[7:6]: Level shifter duty low when asserted (low pulse width adjustment) |
| 19:16  | CMD_TDSEL      | <b>TX duty select</b><br>TDSEL[1:0]: Output level shifter duty high when asserted (high pulse width adjustment)<br>TDSEL[3:2]: Output level shifter duty low when asserted (low pulse width adjustment)                                                                                                                                                     |
| 12     | REG_CMD_SAMPLE | <b>Select clock edge to latch input bus signal.</b><br>0: Use positive sd clock edge to latch input command<br>1: Use negative sd clock edge to latch input command                                                                                                                                                                                         |
| 10:8   | CMD_E8E4E2     | <b>TX Driving Strength Control.</b>                                                                                                                                                                                                                                                                                                                         |
| 5      | CMD_SMT        | <b>RX input buffer schmit trigger hysteresis control enable. High asserted.</b><br>SMT=1, Schmit Trigger enable                                                                                                                                                                                                                                             |
| 4      | CMD_PUPD       | <b>Pull-up / pull-down selection.</b><br>0: pull-up resistor<br>1: pull-down resistor<br>CMD pad default no pull                                                                                                                                                                                                                                            |
| 3      | CMD_R1         | <b>Select 50K resistor (0: not select, 1: select)</b>                                                                                                                                                                                                                                                                                                       |
| 2      | CMD_Ro         | <b>Select 10K resistor (0: not select, 1: select)</b>                                                                                                                                                                                                                                                                                                       |
| 1      | CMD_IES        | <b>RX input buffer enable. High asserted.</b><br>Datapath: from IO to O. IES=0, O=0                                                                                                                                                                                                                                                                         |
| 0      | CMD_SR         | <b>Output Slew Rate Control. High asserted.</b><br>SR=1, slower slew.<br>SR=0, no slew rate controlled.                                                                                                                                                                                                                                                     |

00000108 DAToIOCR T28LP

## Data o Pad Macro IO Control Register

000A0422

| Bit  | 31 | 30 | 29                 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19                 | 18 | 17 | 16 |
|------|----|----|--------------------|----|----|----|----|----|----|----|----|----|--------------------|----|----|----|
| Name |    |    | <b>DATAo_RDSEL</b> |    |    |    |    |    |    |    |    |    | <b>DATAo_TDSEL</b> |    |    |    |
| Type |    |    | RW                 |    |    |    |    |    |    |    |    |    | RW                 |    |    |    |

|        |    |    |    |                         |    |    |   |   |   |   |               |                |             |             |               |             |   |
|--------|----|----|----|-------------------------|----|----|---|---|---|---|---------------|----------------|-------------|-------------|---------------|-------------|---|
| Rese t |    |    | 0  | 0                       | 0  | 0  | 0 | 0 |   |   |               |                | 1           | 0           | 1             | 1           | 0 |
| Bit    | 15 | 14 | 13 | 12                      | 11 | 10 | 9 | 8 | 7 | 6 | 5             | 4              | 3           | 2           | 1             | 0           |   |
| Name   |    |    |    | RE G_ DA TA o_ SA MP LE |    |    |   |   |   |   | DA TA o_ SM T | DA TA o_ PU PD | DA TA o_ R1 | DA TA o_ Ro | DA TA o_ I ES | DA TA o_ SR |   |
| Type   |    |    |    | RW                      |    |    |   |   |   |   | RW            | RW             | RW          | RW          | RW            | RW          |   |
| Rese t |    |    |    | 0                       |    | 1  | 0 | 0 |   |   | 1             | 0              | 0           | 0           | 1             | 0           |   |

| Bit(s) | Name             | Description                                                                                                                                                                                                                                                                                                                                                 |
|--------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29:24  | DATAo_RDSEL      | <b>RX duty select</b><br>RDSEL[1:0]: Input buffer duty high when asserted (high pulse width adjustment)<br>RDSEL[3:2]: Input buffer duty low when asserted (low pulse width adjustment)<br>RDSEL[5:4]: Level shifter duty high when asserted (high pulse width adjustment)<br>RDSEL[7:6]: Level shifter duty low when asserted (low pulse width adjustment) |
| 19:16  | DATAo_TDSEL      | <b>TX duty select</b><br>TDSEL[1:0]: Output level shifter duty high when asserted (high pulse width adjustment)<br>TDSEL[3:2]: Output level shifter duty low when asserted (low pulse width adjustment)                                                                                                                                                     |
| 12     | REG_DATAo_SAMPLE | <b>Select clock edge to latch input bus signal.</b><br>0: Use positive SD clock edge to latch input data<br>1: Use negative SD clock edge to latch input data                                                                                                                                                                                               |
| 10:8   | DATAo_E8E4E2     | <b>TX Driving Strength Control.</b>                                                                                                                                                                                                                                                                                                                         |
| 5      | DATAo_SMT        | <b>RX input buffer Schmitt trigger hysteresis control enabled. High asserted.</b><br>SMT=1, Schmitt Trigger enable                                                                                                                                                                                                                                          |
| 4      | DATAo_PUPD       | <b>Pull-up / pull-down selection.</b><br>0: pull-up resistor<br>1: pull-down resistor<br>DATAo pad default no pull                                                                                                                                                                                                                                          |
| 3      | DATAo_R1         | <b>Select 50K resistor (0: not select, 1: select)</b>                                                                                                                                                                                                                                                                                                       |
| 2      | DATAo_R0         | <b>Select 10K resistor (0: not select, 1: select)</b>                                                                                                                                                                                                                                                                                                       |
| 1      | DATAo_IES        | <b>RX input buffer enable. High asserted.</b><br>Datapath: from IO to O. IES=0, O=0                                                                                                                                                                                                                                                                         |
| 0      | DATAo_SR         | <b>Output Slew Rate Control. High asserted.</b><br>SR=1, slower slew.<br>SR=0, no slew rate controlled.                                                                                                                                                                                                                                                     |

|          |                |                                      |          |              |    |    |    |    |    |    |              |              |             |             |               |             |
|----------|----------------|--------------------------------------|----------|--------------|----|----|----|----|----|----|--------------|--------------|-------------|-------------|---------------|-------------|
| 0000010C | DAT1IOCR_T28LP | Data 1 Pad Macro IO Control Register | 000A0422 |              |    |    |    |    |    |    |              |              |             |             |               |             |
| Bit      | 31             | 30                                   | 29       | 28           | 27 | 26 | 25 | 24 | 23 | 22 | 21           | 20           | 19          | 18          | 17            | 16          |
| Name     |                |                                      |          |              |    |    |    |    |    |    |              |              |             |             |               |             |
| Type     |                |                                      |          |              |    |    |    |    |    |    |              |              |             |             |               |             |
| Rese t   |                |                                      | 0        | 0            | 0  | 0  | 0  | 0  |    |    |              |              | 1           | 0           | 1             | 0           |
| Bit      | 15             | 14                                   | 13       | 12           | 11 | 10 | 9  | 8  | 7  | 6  | 5            | 4            | 3           | 2           | 1             | 0           |
| Name     |                |                                      |          | RE G_ DA TA1 |    |    |    |    |    |    | DA TA1 _S MT | DA TA1 _P UP | DA TA1 _R 1 | DA TA1 _R 0 | DA TA1 _I E S | DA TA1 _S R |
|          |                |                                      |          |              |    |    |    |    |    |    |              |              |             |             |               |             |

|           |  |  |    | S<br>AM<br>PL<br>E |    |   |   |  | D  |    |    |    |    |   |
|-----------|--|--|----|--------------------|----|---|---|--|----|----|----|----|----|---|
| Type      |  |  | RW |                    | RW |   |   |  | RW | RW | RW | RW | RW |   |
| Rese<br>t |  |  | O  |                    | 1  | 0 | 0 |  | 1  | 0  | 0  | 0  | 1  | 0 |

| Bit(s) | Name             | Description                                                                                                                                                                                                                                                                                                                                                 |
|--------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29:24  | DATA1_RDSEL      | <b>RX duty select</b><br>RDSEL[1:0]: Input buffer duty high when asserted (high pulse width adjustment)<br>RDSEL[3:2]: Input buffer duty low when asserted (low pulse width adjustment)<br>RDSEL[5:4]: Level shifter duty high when asserted (high pulse width adjustment)<br>RDSEL[7:6]: Level shifter duty low when asserted (low pulse width adjustment) |
| 19:16  | DATA1_TDSEL      | <b>TX duty select</b><br>TDSEL[1:0]: Output level shifter duty high when asserted (high pulse width adjustment)<br>TDSEL[3:2]: Output level shifter duty low when asserted (low pulse width adjustment)                                                                                                                                                     |
| 12     | REG_DATA1_SAMPLE | <b>Select clock edge to latch input bus signal.</b><br>0: Use positive SD clock edge to latch input data 1<br>1: Use negative SD clock edge to latch input data 1                                                                                                                                                                                           |
| 10:8   | DATA1_E8E4E2     | <b>TX Driving Strength Control.</b>                                                                                                                                                                                                                                                                                                                         |
| 5      | DATA1_SMT        | <b>RX input buffer Schmitt trigger hysteresis control enable. High asserted.</b><br>SMT=1, Schmitt Trigger enable                                                                                                                                                                                                                                           |
| 4      | DATA1_PUPD       | <b>Pull-up / pull-down selection.</b><br>0: pull-up resistor<br>1: pull-down resistor<br>DATA 1 pad default no pull                                                                                                                                                                                                                                         |
| 3      | DATA1_R1         | <b>Select 50K resistor (0: not select, 1: select)</b>                                                                                                                                                                                                                                                                                                       |
| 2      | DATA1_R0         | <b>Select 10K resistor (0: not select, 1: select)</b>                                                                                                                                                                                                                                                                                                       |
| 1      | DATA1_IES        | <b>RX input buffer enable. High asserted.</b><br>Datapath: from IO to O. IES=0, O=0                                                                                                                                                                                                                                                                         |
| 0      | DATA1_SR         | <b>Output Slew Rate Control. High asserted.</b><br>SR=1, slower slew.<br>SR=0, no slew rate controlled.                                                                                                                                                                                                                                                     |

| 00000110 DAT2IOCR T28LP Data 2 Pad Macro IO Control Register 000A0422 |    |    |    |          |    |    |    |    |    |    |                |                |                |                |                |                |   |
|-----------------------------------------------------------------------|----|----|----|----------|----|----|----|----|----|----|----------------|----------------|----------------|----------------|----------------|----------------|---|
| Bit                                                                   | 31 | 30 | 29 | 28       | 27 | 26 | 25 | 24 | 23 | 22 | 21             | 20             | 19             | 18             | 17             | 16             |   |
| Name                                                                  |    |    |    |          |    |    |    |    |    |    |                |                |                |                |                |                |   |
| Type                                                                  |    |    |    |          |    |    |    |    |    |    |                |                |                |                |                |                |   |
| Rese<br>t                                                             |    |    |    | 0        | 0  | 0  | 0  | 0  | 0  |    |                |                |                | 1              | 0              | 1              | 0 |
| Bit                                                                   | 15 | 14 | 13 | 12       | 11 | 10 | 9  | 8  | 7  | 6  | 5              | 4              | 3              | 2              | 1              | 0              |   |
| Name                                                                  |    |    |    | RE<br>G_ | DA | TA | 2_ | SA | MP | LE | DA<br>TA<br>2_ | DA<br>TA<br>2_ | DA<br>TA<br>2_ | DA<br>TA<br>2_ | DA<br>TA<br>2_ | DA<br>TA<br>2_ |   |
| Type                                                                  |    |    |    |          |    |    |    |    |    |    |                |                |                |                |                |                |   |
| Rese<br>t                                                             |    |    |    |          | RW |    |    |    |    |    | RW             | RW             | RW             | RW             | RW             | RW             |   |
| Type                                                                  |    |    |    |          | O  |    | 1  | 0  | 0  |    | 1              | 0              | 0              | 0              | 1              | 0              |   |

| Bit(s) | Name             | Description                                                                                                                                                                                                                                                                                                                                                 |
|--------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29:24  | DATA2_RDSEL      | <b>RX duty select</b><br>RDSEL[1:0]: Input buffer duty high when asserted (high pulse width adjustment)<br>RDSEL[3:2]: Input buffer duty low when asserted (low pulse width adjustment)<br>RDSEL[5:4]: Level shifter duty high when asserted (high pulse width adjustment)<br>RDSEL[7:6]: Level shifter duty low when asserted (low pulse width adjustment) |
| 19:16  | DATA2_TDSEL      | <b>TX duty select</b><br>TDSEL[1:0]: Output level shifter duty high when asserted (high pulse width adjustment)<br>TDSEL[3:2]: Output level shifter duty low when asserted (low pulse width adjustment)                                                                                                                                                     |
| 12     | REG_DATA2_SAMPLE | <b>Select clock edge to latch input bus signal.</b><br>0: Use positive SD clock edge to latch input data 2<br>1: Use negative SD clock edge to latch input data 2                                                                                                                                                                                           |
| 10:8   | DATA2_E8E4E2     | <b>TX Driving Strength Control.</b>                                                                                                                                                                                                                                                                                                                         |
| 5      | DATA2_SMT        | <b>RX input buffer Schmitt trigger hysteresis control enable. High asserted.</b>                                                                                                                                                                                                                                                                            |
| 4      | DATA2_PUPD       | <b>Pull-up / pull-down selection.</b><br>0: pull-up resistor<br>1: pull-down resistor<br>DATA 2 pad default no pull                                                                                                                                                                                                                                         |
| 3      | DATA2_R1         | <b>Select 50K resistor (0: not select, 1: select)</b>                                                                                                                                                                                                                                                                                                       |
| 2      | DATA2_R0         | <b>Select 10K resistor (0: not select, 1: select)</b>                                                                                                                                                                                                                                                                                                       |
| 1      | DATA2_IES        | <b>RX input buffer enable. High asserted.</b><br>Datapath: from IO to O. IES=0, O=0                                                                                                                                                                                                                                                                         |
| 0      | DATA2_SR         | <b>Output Slew Rate Control. High asserted.</b><br>SR=1, slower slew.<br>SR=0, no slew rate controlled.                                                                                                                                                                                                                                                     |

| 00000114 DAT3IOCR T28LP Data 3 Pad Macro IO Control Register 000A042A |                     |    |    |    |    |    |    |    |    |    |             |    |    |    |    |    |
|-----------------------------------------------------------------------|---------------------|----|----|----|----|----|----|----|----|----|-------------|----|----|----|----|----|
| Bit                                                                   | 31                  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21          | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b>                                                           | DATA3_RDSEL         |    |    |    |    |    |    |    |    |    | DATA3_TDSEL |    |    |    |    |    |
| <b>Type</b>                                                           | RW                  |    |    |    |    |    |    |    |    |    | RW          |    |    |    |    |    |
| <b>Rese t</b>                                                         | 0 0 0 0 0 0 0 0 0 0 |    |    |    |    |    |    |    |    |    | 1           | 0  | 1  | 0  |    |    |
| <b>Bit</b>                                                            | 15                  | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5           | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>                                                           | RE                  |    | G_ |    | DA |    | TA |    | 3_ |    | SM          |    | DA |    | DA |    |
|                                                                       | SA                  |    | E  |    | PU |    | PD |    | R1 |    | R0          |    | I  |    | SR |    |
| <b>Type</b>                                                           | RW                  |    | RW |    | RW |    | RW |    | RW |    | RW          |    | RW |    | RW |    |
| <b>Rese t</b>                                                         | 0                   |    | 1  |    | 0  |    | 0  |    | 1  |    | 0           |    | 1  |    | 0  |    |

| Bit(s) | Name        | Description                                                                                                                                                                 |
|--------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29:24  | DATA3_RDSEL | <b>RX duty select</b><br>RDSEL[1:0]: Input buffer duty high when asserted (high pulse width adjustment)<br>RDSEL[3:2]: Input buffer duty low when asserted (low pulse width |

| Bit(s) | Name             | Description                                                                                                                                                                                                                                                 |
|--------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19:16  | DATA3_TDSEL      | adjustment)<br>RDSEL[5:4]: Level shifter duty high when asserted (high pulse width adjustment)<br>RDSEL[7:6]: Level shifter duty low when asserted (low pulse width adjustment)                                                                             |
| 12     | REG_DATA3_SAMPLE | <b>TX duty select</b><br>TDSEL[1:0]: Output level shifter duty high when asserted (high pulse width adjustment)<br>TDSEL[3:2]: Output level shifter duty low when asserted (low pulse width adjustment)                                                     |
| 10:8   | DATA3_E8E4E2     | <b>Select clock edge to latch input bus signal.</b><br>0: Use positive SD clock edge to latch input data 3<br>1: Use negative SD clock edge to latch input data 3                                                                                           |
| 5      | DATA3_SMT        | <b>RX input buffer Schmitt trigger hysteresis control enable. High asserted.</b><br>SMT=1, Schmitt Trigger enable                                                                                                                                           |
| 4      | DATA3_PUPD       | <b>Pull-up / pull-down selection.</b><br>0: pull-up resistor<br>1: pull-down resistor<br>DATA 3 pad default would pull up with 50K resistor. (for card detection)<br>After host driver writes cd_disable to CCCR register, data 3 pad would become no pull. |
| 3      | DATA3_R1         | <b>Select 50K resistor (0: not select, 1: select)</b>                                                                                                                                                                                                       |
| 2      | DATA3_R0         | <b>Select 10K resistor (0: not select, 1: select)</b>                                                                                                                                                                                                       |
| 1      | DATA3_IES        | <b>RX input buffer enable. High asserted.</b><br>Datapath: from IO to O. IES=0, O=0                                                                                                                                                                         |
| 0      | DATA3_SR         | <b>Output Slew Rate Control. High asserted.</b><br>SR=1, slower slew.<br>SR=0, no slew rate controlled.                                                                                                                                                     |

| 00000118 CLKDLYCR Clock Pad Macro Delay Chain Control Register 00000000 |    |    |    |    |    |    |    |    |                                                 |    |    |    |                    |          |          |          |
|-------------------------------------------------------------------------|----|----|----|----|----|----|----|----|-------------------------------------------------|----|----|----|--------------------|----------|----------|----------|
| Bit                                                                     | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23                                              | 22 | 21 | 20 | 19                 | 18       | 17       | 16       |
| <b>Name</b>                                                             |    |    |    |    |    |    |    |    |                                                 |    |    |    |                    |          |          |          |
| <b>Type</b>                                                             |    |    |    |    |    |    |    |    |                                                 |    |    |    |                    |          |          |          |
| <b>Reset</b>                                                            |    |    |    |    |    |    |    |    |                                                 |    |    |    |                    |          |          |          |
| Bit                                                                     | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7                                               | 6  | 5  | 4  | 3                  | 2        | 1        | 0        |
| <b>Name</b>                                                             |    |    |    |    |    |    |    |    | <b>RE<br/>G<br/>CK<br/>D<br/>LY<br/>E<br/>N</b> |    |    |    | <b>CLK_DLY_SEL</b> |          |          |          |
| <b>Type</b>                                                             |    |    |    |    |    |    |    |    | <b>RW</b>                                       |    |    |    | <b>RW</b>          |          |          |          |
| <b>Reset</b>                                                            |    |    |    |    |    |    |    |    | <b>0</b>                                        |    |    |    | <b>0</b>           | <b>0</b> | <b>0</b> | <b>0</b> |

| Bit(s) | Name          | Description                                                                                                                                     |
|--------|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 7      | REG_CK_DLY_EN | <b>Enable input clock through delay chain.</b><br>0: Input clock does not pass through delay chain.<br>1: Input clock pass through delay chain. |
| 4:0    | CLK_DLY_SEL   | <b>CLK Pad Input Delay Control</b><br>This register is used to add delay to CLK phase.<br>Total 32 stages                                       |

| Bit(s)       | Name                                                   | Description                                                                                                         |    |               |    |    |    |    |                                                        |    |    |               |    |    |    |          |
|--------------|--------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|----|---------------|----|----|----|----|--------------------------------------------------------|----|----|---------------|----|----|----|----------|
| 0000011C     | <u>CMDDLYCR</u>                                        | <b>Command Pad Macro Delay Chain Control Register</b>                                                               |    |               |    |    |    |    |                                                        |    |    |               |    |    |    | 00000000 |
| <b>Bit</b>   | 31                                                     | 30                                                                                                                  | 29 | 28            | 27 | 26 | 25 | 24 | 23                                                     | 22 | 21 | 20            | 19 | 18 | 17 | 16       |
| <b>Name</b>  |                                                        |                                                                                                                     |    |               |    |    |    |    | RE<br>G_<br>CM<br>D_<br>D_<br>O_<br>DL<br>Y_<br>EN     |    |    | CMD_O_DLY     |    |    |    |          |
| <b>Type</b>  |                                                        |                                                                                                                     |    |               |    |    |    |    | RW                                                     | RW |    | RW            |    |    |    |          |
| <b>Reset</b> |                                                        |                                                                                                                     |    |               |    |    |    |    | o                                                      | o  |    | o             | o  | o  | o  | o        |
| <b>Bit</b>   | 15                                                     | 14                                                                                                                  | 13 | 12            | 11 | 10 | 9  | 8  | 7                                                      | 6  | 5  | 4             | 3  | 2  | 1  | 0        |
| <b>Name</b>  | RE<br>G_<br>CM<br>D_<br>NE<br>G_I<br>D<br>LY<br>E<br>N |                                                                                                                     |    | CMD_NEG_I_DLY |    |    |    |    | RE<br>G_<br>CM<br>D_<br>PO<br>S_I<br>D<br>LY<br>E<br>N |    |    | CMD_POS_I_DLY |    |    |    |          |
| <b>Type</b>  | RW                                                     |                                                                                                                     |    | RW            |    |    |    |    | RW                                                     |    |    | RW            |    |    |    |          |
| <b>Reset</b> | o                                                      |                                                                                                                     |    | o             | o  | o  | o  | o  | o                                                      |    |    | o             | o  | o  | o  | o        |
| Bit(s)       | Name                                                   | Description                                                                                                         |    |               |    |    |    |    |                                                        |    |    |               |    |    |    |          |
| 23           | REG_CMD_O_DLY_EN                                       | <b>Enable output response through delay chain. (to I of IOCUP)</b>                                                  |    |               |    |    |    |    |                                                        |    |    |               |    |    |    |          |
| 22           | REG_CMD_OE_DLY_EN                                      | o: Output response does not pass through delay chain.<br>1: Output response pass through delay chain.               |    |               |    |    |    |    |                                                        |    |    |               |    |    |    |          |
| 20:16        | CMD_O_DLY                                              | <b>Enable response output enable through delay chain. (to E of IOCUP)</b>                                           |    |               |    |    |    |    |                                                        |    |    |               |    |    |    |          |
| 15           | REG_CMD_NEG_I_DLY_EN                                   | o: Response output enable does not pass through delay chain.<br>1: Response output enable pass through delay chain. |    |               |    |    |    |    |                                                        |    |    |               |    |    |    |          |
| 12:8         | CMD_NEG_I_DLY                                          | <b>CMD Pad Output Delay Control</b>                                                                                 |    |               |    |    |    |    |                                                        |    |    |               |    |    |    |          |
| 7            | REG_CMD_POS_I_DLY_EN                                   | This register is used to add delay to output response phase.<br>Total 32 stages                                     |    |               |    |    |    |    |                                                        |    |    |               |    |    |    |          |
| 4:0          | CMD_POS_I_DLY                                          | <b>Enable input command through delay chain to be latched with negative clock edge.</b>                             |    |               |    |    |    |    |                                                        |    |    |               |    |    |    |          |
|              |                                                        | o: Input command does not pass through delay chain.<br>1: Input command pass through delay chain.                   |    |               |    |    |    |    |                                                        |    |    |               |    |    |    |          |
|              |                                                        | <b>CMD Pad Input Delay Control for data latch with negative clock edge.</b>                                         |    |               |    |    |    |    |                                                        |    |    |               |    |    |    |          |
|              |                                                        | This register is used to add delay to input command phase.<br>Total 32 stages                                       |    |               |    |    |    |    |                                                        |    |    |               |    |    |    |          |
|              |                                                        | <b>Enable input command through delay chain to be latched with positive clock edge.</b>                             |    |               |    |    |    |    |                                                        |    |    |               |    |    |    |          |
|              |                                                        | o: Input command does not pass through delay chain.<br>1: Input command pass through delay chain.                   |    |               |    |    |    |    |                                                        |    |    |               |    |    |    |          |
|              |                                                        | <b>CMD Pad Input Delay Control for data latch with positive clock edge.</b>                                         |    |               |    |    |    |    |                                                        |    |    |               |    |    |    |          |
|              |                                                        | This register is used to add delay to input command phase.<br>Total 32 stages                                       |    |               |    |    |    |    |                                                        |    |    |               |    |    |    |          |

**00000120 ODATDLYCR****SDIO Output Data Delay Chain Control Register**

| Bit    | 31                              | 30                              | 29 | 28         | 27 | 26 | 25 | 24 | 23                              | 22                              | 21 | 20         | 19 | 18 | 17 | 16 |
|--------|---------------------------------|---------------------------------|----|------------|----|----|----|----|---------------------------------|---------------------------------|----|------------|----|----|----|----|
| Name   | RE<br>G_ DA<br>T3_O_D LY<br>E_N | RE<br>G_ DA<br>T3_O_D LY<br>E_N |    | DAT3_O_DLY |    |    |    |    | RE<br>G_ DA<br>T2_O_D LY<br>E_N | RE<br>G_ DA<br>T2_O_D LY<br>E_N |    | DAT2_O_DLY |    |    |    |    |
| Type   | RW                              | RW                              |    | RW         |    |    |    |    | RW                              | RW                              |    | RW         |    |    |    |    |
| Rese t | o                               | o                               |    | o          | o  | o  | o  | o  | o                               | o                               |    | o          | o  | o  | o  | o  |
| Bit    | 15                              | 14                              | 13 | 12         | 11 | 10 | 9  | 8  | 7                               | 6                               | 5  | 4          | 3  | 2  | 1  | 0  |
| Name   | RE<br>G_ DA<br>T1_O_D LY<br>E_N | RE<br>G_ DA<br>T1_O_D LY<br>E_N |    | DAT1_O_DLY |    |    |    |    | RE<br>G_ DA<br>To_O_E_N         | RE<br>G_ DA<br>To_O_E_N         |    | DATo_O_DLY |    |    |    |    |
| Type   | RW                              | RW                              |    | RW         |    |    |    |    | RW                              | RW                              |    | RW         |    |    |    |    |
| Rese t | o                               | o                               |    | o          | o  | o  | o  | o  | o                               | o                               |    | o          | o  | o  | o  | o  |

| Bit(s) | Name               | Description                                                                                                                                                                                |
|--------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31     | REG_DAT3_O_DLY_EN  | <b>Enable output data 3 through delay chain. (to I of IOCUP)</b><br>0: Output data 3 does not pass through delay chain.<br>1: Output data 3 pass through delay chain.                      |
| 30     | REG_DAT3_OE_DLY_EN | <b>Enable data 3 output enable through delay chain. (to E of IOCUP)</b><br>0: Data 3 output enable does not pass through delay chain.<br>1: Data 3 output enable pass through delay chain. |
| 28:24  | DAT3_O_DLY         | <b>DATA 3 Pad Output Delay Control</b><br>This register is used to add delay to output response phase.<br>Total 32 stages                                                                  |
| 23     | REG_DAT2_O_DLY_EN  | <b>Enable output data 2 through delay chain. (to I of IOCUP)</b><br>0: Output data 2 does not pass through delay chain.<br>1: Output data 2 pass through delay chain.                      |
| 22     | REG_DAT2_OE_DLY_EN | <b>Enable data 2 output enable through delay chain. (to E of IOCUP)</b><br>0: Data 2 output enable does not pass through delay chain.<br>1: Data 2 output enable pass through delay chain. |
| 20:16  | DAT2_O_DLY         | <b>DATA 2 Pad Output Delay Control</b><br>This register is used to add delay to output response phase.<br>Total 32 stages                                                                  |
| 15     | REG_DAT1_O_DLY_EN  | <b>Enable output data 1 through delay chain. (to I of IOCUP)</b><br>0: Output data 1 does not pass through delay chain.<br>1: Output data 1 pass through delay chain.                      |
| 14     | REG_DAT1_OE_DLY_EN | <b>Enable data 1 output enable through delay chain. (to E of IOCUP)</b><br>0: Data 1 output enable does not pass through delay chain.<br>1: Data 1 output enable pass through delay chain. |
| 12:8   | DAT1_O_DLY         | <b>DATA 1 Pad Output Delay Control</b><br>This register is used to add delay to output response phase.<br>Total 32 stages                                                                  |
| 7      | REG_DATo_O_DLY_EN  | <b>Enable output data 0 through delay chain. (to I of IOCUP)</b><br>0: Output data 0 does not pass through delay chain.                                                                    |

| Bit(s) | Name               | Description                                                                                                                                                                                                                                                                                                                                                           |
|--------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6      | REG_DATo_OE_DLY_EN | 1: Output data o pass through delay chain.<br><b>Enable data o output enable through delay chain. (to E of IOCUP)</b><br>0: Data o output enable does not pass through delay chain.<br>1: Data o output enable pass through delay chain.<br><b>DATA o Pad Output Delay Control</b><br>This register is used to add delay to output response phase.<br>Total 32 stages |
| 4:0    | DATo_O_DLY         |                                                                                                                                                                                                                                                                                                                                                                       |

**00000124 IDATDLYCR1 SDIO Input Data Delay Chain Control Register 1 00000000**

| Bit   | 31                                         | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23                                        | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|--------------------------------------------|----|----|----|----|----|----|----|-------------------------------------------|----|----|----|----|----|----|----|
| Name  | RE<br>G_ DA<br>T3<br>P OS<br>I DL<br>Y EN  |    |    |    |    |    |    |    | RE<br>G_ DA<br>T2<br>P OS<br>I DL<br>Y EN |    |    |    |    |    |    |    |
| Type  | RW                                         |    |    |    |    |    |    |    | RW                                        |    |    |    |    |    |    |    |
| Reset | 0                                          |    |    | 0  | 0  | 0  | 0  | 0  | 0                                         |    |    | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15                                         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7                                         | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | RE<br>G_ DA<br>T1<br>PO S_I<br>D LY<br>E N |    |    |    |    |    |    |    | RE<br>G_ DA<br>To<br>P OS<br>I DL<br>Y EN |    |    |    |    |    |    |    |
| Type  | RW                                         |    |    |    |    |    |    |    | RW                                        |    |    |    |    |    |    |    |
| Reset | 0                                          |    |    | 0  | 0  | 0  | 0  | 0  | 0                                         |    |    | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name                  | Description                                                                                                                                                                                                                                                                                                                                                 |
|--------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31     | REG_DAT3_POS_I_DLY_EN | <b>Enable input data 3 through delay chain to be latched with positive clock edge.</b><br>0: Input data 3 does not pass through delay chain.<br>1: Input data 3 pass through delay chain.<br><b>DATA 3 Pad Input Delay Control for data latch with positive clock edge.</b><br>This register is used to add delay to input data 3 phase.<br>Total 32 stages |
| 28:24  | DAT3_POS_I_DLY        |                                                                                                                                                                                                                                                                                                                                                             |
| 23     | REG_DAT2_POS_I_DLY_EN | <b>Enable input data 2 through delay chain to be latched with positive clock edge.</b><br>0: Input data 2 does not pass through delay chain.<br>1: Input data 2 pass through delay chain.<br><b>DATA 2 Pad Input Delay Control for data latch with positive clock edge.</b><br>This register is used to add delay to input data 2 phase.<br>Total 32 stages |
| 20:16  | DAT2_POS_I_DLY        |                                                                                                                                                                                                                                                                                                                                                             |
| 15     | REG_DAT1_POS_I_DLY_EN | <b>Enable input data 1 through delay chain to be latched with positive clock edge.</b><br>0: Input data 1 does not pass through delay chain.<br>1: Input data 1 pass through delay chain.                                                                                                                                                                   |

| Bit(s) | Name                  | Description                                                                                                                                                                               |
|--------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12:8   | DAT1_POS_I_DLY        | <b>DATA 1 Pad Input Delay Control for data latch with positive clock edge.</b><br>This register is used to add delay to input data 1 phase.<br>Total 32 stages                            |
| 7      | REG_DATo_POS_I_DLY_EN | <b>Enable input data o through delay chain to be latched with positive clock edge.</b><br>0: Input data o does not pass through delay chain.<br>1: Input data o pass through delay chain. |
| 4:0    | DATo_POS_I_DLY        | <b>DATA o Pad Input Delay Control for data latch with positive clock edge.</b><br>This register is used to add delay to input data o phase.<br>Total 32 stages                            |

**00000128 IDATDLYCR2 SDIO Input Data Delay Chain Control Register 2 00000000**

| Bit          | 31                                           | 30 | 29 | 28                    | 27 | 26 | 25 | 24 | 23                                           | 22 | 21 | 20                    | 19 | 18 | 17 | 16 |
|--------------|----------------------------------------------|----|----|-----------------------|----|----|----|----|----------------------------------------------|----|----|-----------------------|----|----|----|----|
| <b>Name</b>  | RE<br>G_ DA<br>T3<br>_N EG<br>I_ DL<br>Y_ EN |    |    | <b>DAT3_NEG_I_DLY</b> |    |    |    |    | RE<br>G_ DA<br>T2<br>_N EG<br>I_ DL<br>Y_ EN |    |    | <b>DAT2_NEG_I_DLY</b> |    |    |    |    |
| <b>Type</b>  | RW                                           |    |    | RW                    |    |    |    |    | RW                                           |    |    | RW                    |    |    |    |    |
| <b>Reset</b> | 0                                            |    |    | 0                     | 0  | 0  | 0  | 0  | 0                                            |    |    | 0                     | 0  | 0  | 0  | 0  |
| <b>Bit</b>   | 15                                           | 14 | 13 | 12                    | 11 | 10 | 9  | 8  | 7                                            | 6  | 5  | 4                     | 3  | 2  | 1  | 0  |
| <b>Name</b>  | RE<br>G_ DA<br>T1<br>_N EG<br>I_ DL<br>Y_ EN |    |    | <b>DAT1_NEG_I_DLY</b> |    |    |    |    | RE<br>G_ DA<br>To<br>_N EG<br>I_ DL<br>Y_ EN |    |    | <b>DATo_NEG_I_DLY</b> |    |    |    |    |
| <b>Type</b>  | RW                                           |    |    | RW                    |    |    |    |    | RW                                           |    |    | RW                    |    |    |    |    |
| <b>Reset</b> | 0                                            |    |    | 0                     | 0  | 0  | 0  | 0  | 0                                            |    |    | 0                     | 0  | 0  | 0  | 0  |

| Bit(s) | Name                  | Description                                                                                                                                                                               |
|--------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31     | REG_DAT3_NEG_I_DLY_EN | <b>Enable input data 3 through delay chain to be latched with negative clock edge.</b><br>0: Input data 3 does not pass through delay chain.<br>1: Input data 3 pass through delay chain. |
| 28:24  | DAT3_NEG_I_DLY        | <b>DATA 3 Pad Input Delay Control for data latch with negative clock edge.</b><br>This register is used to add delay to input data 3 phase.<br>Total 32 stages                            |
| 23     | REG_DAT2_NEG_I_DLY_EN | <b>Enable input data 2 through delay chain to be latched with negative clock edge.</b><br>0: Input data 2 does not pass through delay chain.<br>1: Input data 2 pass through delay chain. |
| 20:16  | DAT2_NEG_I_DLY        | <b>DATA 2 Pad Input Delay Control for data latch with negative clock edge.</b><br>This register is used to add delay to input data 2 phase.<br>Total 32 stages                            |

| Bit(s) | Name                  | Description                                                                                                                                                                                                                                                                 |
|--------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15     | REG_DAT1_NEG_I_DLY_EN | <b>Enable input data 1 through delay chain to be latched with negative clock edge.</b><br>0: Input data 1 does not pass through delay chain.<br>1: Input data 1 pass through delay chain.<br><b>DATA 1 Pad Input Delay Control for data latch with negative clock edge.</b> |
| 12:8   | DAT1_NEG_I_DLY        | This register is used to add delay to input data 1 phase.<br>Total 32 stages                                                                                                                                                                                                |
| 7      | REG_DATO_NEG_I_DLY_EN | <b>Enable input data o through delay chain to be latched with negative clock edge.</b><br>0: Input data o does not pass through delay chain.<br>1: Input data o pass through delay chain.<br><b>DATA o Pad Input Delay Control for data latch with negative clock edge.</b> |
| 4:0    | DATO_NEG_I_DLY        | This register is used to add delay to input data o phase.<br>Total 32 stages                                                                                                                                                                                                |

| 0000012C ILCHCR |    |    |                      |    |    |    |                      |    |    |                      |    |    |    |    |    | SDIO Input Data Latch Time Control Register |                    | 00011111 |   |   |
|-----------------|----|----|----------------------|----|----|----|----------------------|----|----|----------------------|----|----|----|----|----|---------------------------------------------|--------------------|----------|---|---|
| Bit             | 31 | 30 | 29                   | 28 | 27 | 26 | 25                   | 24 | 23 | 22                   | 21 | 20 | 19 | 18 | 17 | 16                                          | REG_CM_D_LATCH_SEL | RW       | 0 | 1 |
| Name            |    |    |                      |    |    |    |                      |    |    |                      |    |    |    |    |    |                                             |                    |          |   |   |
| Type            |    |    |                      |    |    |    |                      |    |    |                      |    |    |    |    |    |                                             |                    |          |   |   |
| Rese t          |    |    |                      |    |    |    |                      |    |    |                      |    |    |    |    |    |                                             |                    | 0        | 1 |   |
| Bit             | 15 | 14 | 13                   | 12 | 11 | 10 | 9                    | 8  | 7  | 6                    | 5  | 4  | 3  | 2  | 1  | 0                                           |                    |          |   |   |
| Name            |    |    | REG_DA_T3_LATC_H_SEL |    |    |    | REG_DA_T2_LATC_H_SEL |    |    | REG_DA_T1_LATC_H_SEL |    |    |    |    |    | REG_DA_TO_LATC_H_SEL                        |                    |          |   |   |
| Type            |    |    | RW                   |    |    |    | RW                   |    |    | RW                   |    |    |    |    |    | RW                                          |                    |          |   |   |
| Rese t          |    |    | 0                    | 1  |    |    | 0                    | 1  |    |                      | 0  | 1  |    |    |    | 0                                           | 1                  |          |   |   |

| Bit(s) | Name               | Description                                                                                                                                                                                                                                                                                                                                                                                                                            |
|--------|--------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17:16  | REG_CMD_LATCH_SEL  | <b>Control the input command latch timing depending on SDIO output enable signal to avoid latching device output data as host transferred data in UHS104 mode.</b><br>2'boo: latch input command after 1T of output enable asserted<br>2'b01: latch input command after 2T of output enable asserted<br>2'b10: latch input command after 3T of output enable asserted<br>2'b11: latch input command after 4T of output enable asserted |
| 13:12  | REG_DAT3_LATCH_SEL | <b>Control the input data 3 latch timing depending on SDIO output enable signal to avoid latching device output data as host transferred data in UHS104 mode.</b><br>2'boo: latch input data 3 after 1T of output enable asserted<br>2'b01: latch input data 3 after 2T of output enable asserted<br>2'b10: latch input data 3 after 3T of output enable asserted<br>2'b11: latch input data 3 after 4T of output enable asserted      |
| 9:8    | REG_DAT2_LATCH_SEL | <b>Control the input data 2 latch timing depending on SDIO output enable signal to avoid latching device output data as host transferred data in UHS104 mode.</b><br>2'boo: latch input data 2 after 1T of output enable asserted<br>2'b01: latch input data 2 after 2T of output enable asserted<br>2'b10: latch input data 2 after 3T of output enable asserted<br>2'b11: latch input data 2 after 4T of output enable asserted      |
| 5:4    | REG_DAT1_LATCH_SEL | <b>Control the input data 1 latch timing depending on SDIO</b>                                                                                                                                                                                                                                                                                                                                                                         |

| Bit(s) | Name                | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0    | REG_DATo__LATCH_SEL | <p><b>output enable signal to avoid latching device output data as host transferred data in UHS104 mode.</b></p> <p>2'boo: latch input data 1 after 1T of output enable asserted<br/>     2'b01: latch input data 1 after 2T of output enable asserted<br/>     2'b10: latch input data 1 after 3T of output enable asserted<br/>     2'b11: latch input data 1 after 4T of output enable asserted</p> <p><b>Control the input data o latch timing depending on SDIO output enable signal to avoid latching device output data as host transferred data in UHS104 mode.</b></p> <p>2'boo: latch input data o after 1T of output enable asserted<br/>     2'b01: latch input data o after 2T of output enable asserted<br/>     2'b10: latch input data o after 3T of output enable asserted<br/>     2'b11: latch input data o after 4T of output enable asserted</p> |

| <b>00000130 WTQCRO WLAN TXQ Count Register 0 00000000</b> |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-----------------------------------------------------------|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit                                                       | 31              | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b>                                               | <b>TXQ1_CNT</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                                               | <b>RC</b>       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                                              | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |    |
| <b>Bit</b>                                                | 15              | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  |    |
| <b>Name</b>                                               | <b>TXQo_CNT</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                                               | <b>RC</b>       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                                              | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |    |

| Bit(s) | Name     | Description                                                                                                                                                                                               |
|--------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16  | TXQ1_CNT | <p><b>This field indicates the released count of TXQ1 during two WTQCRO read access. The unit can be defined by the driver.</b></p> <p>This field is cleared by read operation. Write has no meaning.</p> |
| 15:0   | TXQo_CNT | <p><b>This field indicates the released count of TXQo during two WTQCRO read access. The unit can be defined by the driver.</b></p> <p>This field is cleared by read operation. Write has no meaning.</p> |

| <b>00000134 WTQCRI WLAN TXQ Count Register 1 00000000</b> |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-----------------------------------------------------------|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit                                                       | 31              | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b>                                               | <b>TXQ3_CNT</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                                               | <b>RC</b>       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                                              | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |    |
| <b>Bit</b>                                                | 15              | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  |    |
| <b>Name</b>                                               | <b>TXQ2_CNT</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                                               | <b>RC</b>       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>                                              | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |    |

| Bit(s) | Name     | Description                                                       |
|--------|----------|-------------------------------------------------------------------|
| 31:16  | TXQ3_CNT | <b>This field indicates the released count of TXQ3 during two</b> |

| Bit(s) | Name     | Description                                                                                                                                                                                                                                                                                                                           |
|--------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0   | TXQ2_CNT | <b>WTQCR1 read access. The unit can be defined by the driver.</b><br>This field is cleared by read operation. Write has no meaning.<br><b>This field indicates the released count of TXQ2 during two WTQCR1 read access. The unit can be defined by the driver.</b><br>This field is cleared by read operation. Write has no meaning. |
|        |          |                                                                                                                                                                                                                                                                                                                                       |

| <b>00000138 WTQCR2 WLAN TXQ Count Register 2 00000000</b> |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-----------------------------------------------------------|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit                                                       | 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b>                                               | TXQ5_CNT |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                                               | RC       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Rese t</b>                                             | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |    |
| <b>Bit</b>                                                | 15       | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  |    |
| <b>Name</b>                                               | TXQ4_CNT |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                                               | RC       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Rese t</b>                                             | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |    |

| Bit(s) | Name     | Description                                                                                                                                                                                    |
|--------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16  | TXQ5_CNT | <b>This field indicates the released count of TXQ5 during two WTQCR2 read access. The unit can be defined by the driver.</b><br>This field is cleared by read operation. Write has no meaning. |
| 15:0   | TXQ4_CNT | <b>This field indicates the released count of TXQ4 during two WTQCR2 read access. The unit can be defined by the driver.</b><br>This field is cleared by read operation. Write has no meaning. |
|        |          |                                                                                                                                                                                                |

| <b>0000013C WTQCR3 WLAN TXQ Count Register 3 00000000</b> |          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-----------------------------------------------------------|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit                                                       | 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b>                                               | TXQ7_CNT |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                                               | RC       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Rese t</b>                                             | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |    |
| <b>Bit</b>                                                | 15       | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  |    |
| <b>Name</b>                                               | TXQ6_CNT |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>                                               | RC       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Rese t</b>                                             | 0        | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |    |

| Bit(s) | Name     | Description                                                                                                                                                                                    |
|--------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16  | TXQ7_CNT | <b>This field indicates the released count of TXQ7 during two WTQCR3 read access. The unit can be defined by the driver.</b><br>This field is cleared by read operation. Write has no meaning. |
| 15:0   | TXQ6_CNT | <b>This field indicates the released count of TXQ6 during two WTQCR3 read access. The unit can be defined by the driver.</b><br>This field is cleared by read operation. Write has no meaning. |
|        |          |                                                                                                                                                                                                |

| Bit(s)          | Name                                            | Description                                                                                                                                                                              |
|-----------------|-------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>00000140</b> | <b>WTQCR4</b>                                   | <b>WLAN TXQ Count Register 4</b>                                                                                                                                                         |
| <b>Bit</b>      | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | <b>00000000</b>                                                                                                                                                                          |
| <b>Name</b>     | <b>TXQ9_CNT</b>                                 |                                                                                                                                                                                          |
| <b>Type</b>     | <b>RC</b>                                       |                                                                                                                                                                                          |
| <b>Reset</b>    | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                                          |
| <b>Bit</b>      | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0           | <b>00000000</b>                                                                                                                                                                          |
| <b>Name</b>     | <b>TXQ8_CNT</b>                                 |                                                                                                                                                                                          |
| <b>Type</b>     | <b>RC</b>                                       |                                                                                                                                                                                          |
| <b>Reset</b>    | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                                          |
| Bit(s)          | Name                                            | Description                                                                                                                                                                              |
| 31:16           | TXQ9_CNT                                        | This field indicates the released count of TXQ9 during two WTQCR4 read access. The unit can be defined by the driver.                                                                    |
| 15:0            | TXQ8_CNT                                        | This field is cleared by read operation. Write has no meaning.<br>This field indicates the released count of TXQ8 during two WTQCR4 read access. The unit can be defined by the driver.  |
|                 |                                                 | This field is cleared by read operation. Write has no meaning.                                                                                                                           |
| <b>00000144</b> | <b>WTQCR5</b>                                   | <b>WLAN TXQ Count Register 5</b>                                                                                                                                                         |
| <b>Bit</b>      | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | <b>00000000</b>                                                                                                                                                                          |
| <b>Name</b>     | <b>TXQ11_CNT</b>                                |                                                                                                                                                                                          |
| <b>Type</b>     | <b>RC</b>                                       |                                                                                                                                                                                          |
| <b>Reset</b>    | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                                          |
| <b>Bit</b>      | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0           | <b>00000000</b>                                                                                                                                                                          |
| <b>Name</b>     | <b>TXQ10_CNT</b>                                |                                                                                                                                                                                          |
| <b>Type</b>     | <b>RC</b>                                       |                                                                                                                                                                                          |
| <b>Reset</b>    | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                 | 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                                          |
| Bit(s)          | Name                                            | Description                                                                                                                                                                              |
| 31:16           | TXQ11_CNT                                       | This field indicates the released count of TXQ11 during two WTQCR5 read access. The unit can be defined by the driver.                                                                   |
| 15:0            | TXQ10_CNT                                       | This field is cleared by read operation. Write has no meaning.<br>This field indicates the released count of TXQ10 during two WTQCR5 read access. The unit can be defined by the driver. |
|                 |                                                 | This field is cleared by read operation. Write has no meaning.                                                                                                                           |
| <b>00000148</b> | <b>WTQCR6</b>                                   | <b>WLAN TXQ Count Register 6</b>                                                                                                                                                         |
| <b>Bit</b>      | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 | <b>00000000</b>                                                                                                                                                                          |
| <b>Name</b>     | <b>TXQ13_CNT</b>                                |                                                                                                                                                                                          |

| Type  | RC        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------|-----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Reset | 0         | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Bit   | 15        | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name  | TXQ12_CNT |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | RC        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0         | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| Bit(s) | Name      | Description                                                                                                                                                                                                                                                       |
|--------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16  | TXQ13_CNT | <b>This field indicates the released count of TXQ13 during two WTQCR6 read access. The unit can be defined by the driver.</b>                                                                                                                                     |
| 15:0   | TXQ12_CNT | This field is cleared by read operation. Write has no meaning.<br><b>This field indicates the released count of TXQ12 during two WTQCR6 read access. The unit can be defined by the driver.</b><br>This field is cleared by read operation. Write has no meaning. |

| 0000014C WTQCR7 WLAN TXQ Count Register 7 00000000 |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|----------------------------------------------------|-----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit                                                | 31        | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name                                               | TXQ15_CNT |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                                               | RC        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset                                              | 0         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit                                                | 15        | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name                                               | TXQ14_CNT |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                                               | RC        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset                                              | 0         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name      | Description                                                                                                                                                                                                                                                       |
|--------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:16  | TXQ15_CNT | <b>This field indicates the released count of TXQ15 during two WTQCR7 read access. The unit can be defined by the driver.</b>                                                                                                                                     |
| 15:0   | TXQ14_CNT | This field is cleared by read operation. Write has no meaning.<br><b>This field indicates the released count of TXQ14 during two WTQCR7 read access. The unit can be defined by the driver.</b><br>This field is cleared by read operation. Write has no meaning. |

| 00000154 SWPCDBGR WLAN PC Value debug register 00000000 |              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|---------------------------------------------------------|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit                                                     | 31           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name                                                    | CPU_PC_VALUE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                                                    | RO           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset                                                   | 0            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit                                                     | 15           | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name                                                    | CPU_PC_VALUE |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                                                    | RO           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset                                                   | 0            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

|   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| t |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|

| Bit(s) | Name         | Description                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | CPU_PC_VALUE | <p><b>This field indicates which command the CPU is running and is read out by host software to debug what is wrong in the slave CPU</b></p> <p>This register is read only and can only be read out by one command 53, because the whole 32bits makes a valid CPU status and its content may be updated every AHB clock</p> <p>When reading this register SDIO AHB clock must exist and it does not need driver own right</p> |

| 00000158 DSIOCR DS Pad Macro IO Control Register 000A0422 |    |    |                 |    |    |                  |    |    |    |    |    |               |                 |              |              |              |              |
|-----------------------------------------------------------|----|----|-----------------|----|----|------------------|----|----|----|----|----|---------------|-----------------|--------------|--------------|--------------|--------------|
| Bit                                                       | 31 | 30 | 29              | 28 | 27 | 26               | 25 | 24 | 23 | 22 | 21 | 20            | 19              | 18           | 17           | 16           |              |
| <b>Name</b>                                               |    |    | <b>DS_RDSEL</b> |    |    |                  |    |    |    |    |    |               | <b>DS_TDSEL</b> |              |              |              |              |
| <b>Type</b>                                               |    |    | RW              |    |    |                  |    |    |    |    |    |               | RW              |              |              |              |              |
| <b>Reset</b>                                              |    |    | 0               | 0  | 0  | 0                | 0  | 0  |    |    |    |               | 1               | 0            | 1            | 0            |              |
| <b>Bit</b>                                                | 15 | 14 | 13              | 12 | 11 | 10               | 9  | 8  | 7  | 6  | 5  | 4             | 3               | 2            | 1            | 0            |              |
| <b>Name</b>                                               |    |    |                 |    |    | <b>DS_E8E4E2</b> |    |    |    |    |    | <b>DS_SMT</b> | <b>DS_PUPD</b>  | <b>DS_R1</b> | <b>DS_RO</b> | <b>DSIES</b> | <b>DS_SR</b> |
| <b>Type</b>                                               |    |    |                 |    |    | RW               |    |    |    |    |    | RW            | RW              | RW           | RW           | RW           |              |
| <b>Reset</b>                                              |    |    |                 |    |    | 1                | 0  | 0  |    |    |    | 1             | 0               | 0            | 0            | 1            |              |

| Bit(s) | Name      | Description                                                                                                                                                                                                                                                                                                                                                                        |
|--------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29:24  | DS_RDSEL  | <p><b>RX duty select</b></p> <p>RDSEL[1:0]: Input buffer duty high when asserted (high pulse width adjustment)</p> <p>RDSEL[3:2]: Input buffer duty low when asserted (low pulse width adjustment)</p> <p>RDSEL[5:4]: Level shifter duty high when asserted (high pulse width adjustment)</p> <p>RDSEL[7:6]: Level shifter duty low when asserted (low pulse width adjustment)</p> |
| 19:16  | DS_TDSEL  | <p><b>TX duty select</b></p> <p>TDSEL[1:0]: Output level shifter duty high when asserted (high pulse width adjustment)</p> <p>TDSEL[3:2]: Output level shifter duty low when asserted (low pulse width adjustment)</p>                                                                                                                                                             |
| 10:8   | DS_E8E4E2 | <b>TX Driving Strength Control.</b>                                                                                                                                                                                                                                                                                                                                                |
| 5      | DS_SMT    | <b>RX input buffer Schmitt trigger hysteresis control enable. High asserted.</b>                                                                                                                                                                                                                                                                                                   |
| 4      | DS_PUPD   | SMT=1, Schmitt Trigger enable<br><b>Pull-up / pull-down selection.</b><br>0: pull-up resistor<br>1: pull-down resistor<br>CLK pad default no pull                                                                                                                                                                                                                                  |
| 3      | DS_R1     | <b>Select 50K resistor (0: not select, 1: select)</b>                                                                                                                                                                                                                                                                                                                              |
| 2      | DS_RO     | <b>Select 10K resistor (0: not select, 1: select)</b>                                                                                                                                                                                                                                                                                                                              |
| 1      | DSIES     | <b>RX input buffer enable. High asserted.</b><br>Datapath: from IO to O. IES=0, O=0                                                                                                                                                                                                                                                                                                |
| 0      | DS_SR     | <b>Output Slew Rate Control. High asserted.</b><br>SR=1, slower slew.<br>SR=0, no slew rate controlled.                                                                                                                                                                                                                                                                            |

## 14. General Purpose Timer

### 14.1. Overview

The general purpose timer (GPT) includes five 32-bit timers and one 64-bit timer. Each timer has four operation modes, ONE-SHOT, REPEAT, freerun with interrupt (FREERUN\_I), and FREERUN, and can operate on either system clock (13MHz) or real-time clock (RTC). The GPT is an always-on IP, which means it retains the previous configuration and runs even if the system enters sleep mode. Note that in sleep mode, the clock source should be set to RTC since there is no system clock.

### 14.2. Features

#### 14.2.1. Timer mode

Each GPT has four modes, ONE-SHOT, REPEAT, FREERUN\_I, and FREERUN.

- ONE-SHOT mode. An interrupt occurs and the timer stops once GPT is timed out.
- REPEAT mode. An interrupt occurs and the timer resets once GPT is timed out.
- FREERUN\_I mode. An interrupt occurs and the timer continues once the GPT is timed out.
- FREERUN mode. The GPT continues counting with no limit.

#### 14.2.2. Timer clock source

Each GPT can operate on either system clock (13MHz) or RTC. There is also a 4-bit clock divider, which divides the clock by 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 16, 32, or 64. Note, that in sleep mode, only RTC is available.

#### 14.2.3. Timer interrupt source

All GPTs share a single interrupt source. The user can get the interrupt status by reading GPT\_IRQSTA[5:0] and GPTx\_IRQ\_STA. To clear the interrupt, write 1 to GPTx\_IRQ\_ACK.

#### 14.2.4. System wakeup source

The interrupt signal is also connected to System Power Management (SPM) as a wakeup source.

### 14.3. Limitations

The following operations take two cycles of bus clock (26MHz) plus two cycles of system or RTC clock to take effect.

- Start GPT
- Stop GPT
- Clear GPT
- Set compare value

Every two clear commands need to be separated by 5 cycles of bus clock and 4 cycles of system or RTC clock.

Every two set compare value commands need to be separated by 5 cycles of bus clock and 4 cycles of system or RTC clock.

## 14.4. Block diagram

The block diagram of the GPT is shown in Figure 14.4-1.



Figure 14.4-1. GPT block diagram

## 14.5. Functions

The function of each mode is described in Table 14.5-1.

Table 14.5-1. GPT operation modes

| Mode      | Interrupt | Reached the limit | Example: set GPTx_COMPARE to 2<br><i>*Bold means interrupt</i> |
|-----------|-----------|-------------------|----------------------------------------------------------------|
| ONE-SHOT  | Yes       | Stop              | 0,1, <b>2</b> ,2,2,2,2,2,2,2,2,...                             |
| REPEAT    | Yes       | Restart from 0    | 0,1, <b>2</b> ,0,1, <b>2</b> ,0,1, <b>2</b> ,0,1, <b>2</b> ... |
| FREERUN_I | Yes       | Keep counting     | 0,1, <b>2</b> ,3,4,5,6,7,8,9,10,...                            |
| FREERUN   | No        | Keep counting     | 0,1,2,3,4,5,6,7,8,9,10,...                                     |

## 14.6. Programming sequence

The following configuration is required to initialize the GPT settings:

- 1) Disable GPT clock (GPTx\_CON[16]).
- 2) Set the clock frequency (GPTx\_CLK).
  - Do not change the clock frequency while clock is enabled.
- 3) Enable the clock (GPTx\_CON[16]).
- 4) Clear the counter (GPTx\_CLR).
- 5) Set operation mode (GPTx\_CON[9:8]).

- Do not modify operation mode while GPT is enabled.
- 6) Enable interrupt (GPTx\_IRQ\_EN).
  - 7) Set comparison value (GPTx\_COMPAREx).
  - 8) Enable the GPT (GPTx\_CON[0]).

## 14.7. Register mapping

**Module name: APXGPT base address: (+a211000oh)**

| Address  | Name                | Width (bits) | Register Functionality          |
|----------|---------------------|--------------|---------------------------------|
| A2110000 | <u>GPT IRQSTA</u>   | 32           | <b>GPT IRQ status</b>           |
| A2110010 | <u>GPT0 CON</u>     | 32           | <b>GPT0 control</b>             |
| A2110014 | <u>GPT0 CLR</u>     | 32           | <b>Clear GPT0</b>               |
| A2110018 | <u>GPT0 CLK</u>     | 32           | <b>GPT0 clock setting</b>       |
| A211001C | <u>GPT0 IRQ EN</u>  | 32           | <b>GPT0 IRQ enable</b>          |
| A2110020 | <u>GPT0 IRQ STA</u> | 32           | <b>GPT0 IRQ status</b>          |
| A2110024 | <u>GPT0 IRQ ACK</u> | 32           | <b>GPT0 IRQ acknowledgement</b> |
| A2110028 | <u>GPT0 COUNT</u>   | 32           | <b>GPT0 counter value</b>       |
| A211002C | <u>GPT0 COMPARE</u> | 32           | <b>GPT0 compare value</b>       |
| A2110040 | <u>GPT1 CON</u>     | 32           | <b>GPT1 control</b>             |
| A2110044 | <u>GPT1 CLR</u>     | 32           | <b>Clear GPT1</b>               |
| A2110048 | <u>GPT1 CLK</u>     | 32           | <b>GPT1 clock setting</b>       |
| A211004C | <u>GPT1 IRQ EN</u>  | 32           | <b>GPT1 IRQ enable</b>          |
| A2110050 | <u>GPT1 IRQ STA</u> | 32           | <b>GPT1 IRQ status</b>          |
| A2110054 | <u>GPT1 IRQ ACK</u> | 32           | <b>GPT1 IRQ acknowledgement</b> |
| A2110058 | <u>GPT1 COUNT</u>   | 32           | <b>GPT1 counter value</b>       |
| A211005C | <u>GPT1 COMPARE</u> | 32           | <b>GPT1 compare value</b>       |
| A2110070 | <u>GPT2 CON</u>     | 32           | <b>GPT2 control</b>             |
| A2110074 | <u>GPT2 CLR</u>     | 32           | <b>Clear GPT2</b>               |
| A2110078 | <u>GPT2 CLK</u>     | 32           | <b>GPT2 clock setting</b>       |
| A211007C | <u>GPT2 IRQ EN</u>  | 32           | <b>GPT2 IRQ enable</b>          |
| A2110080 | <u>GPT2 IRQ STA</u> | 32           | <b>GPT2 IRQ status</b>          |
| A2110084 | <u>GPT2 IRQ ACK</u> | 32           | <b>GPT2 IRQ acknowledgement</b> |
| A2110088 | <u>GPT2 COUNT</u>   | 32           | <b>GPT2 Counter value</b>       |
| A211008C | <u>GPT2 COMPARE</u> | 32           | <b>GPT2 compare value</b>       |
| A21100A0 | <u>GPT3 CON</u>     | 32           | <b>GPT3 control</b>             |
| A21100A4 | <u>GPT3 CLR</u>     | 32           | <b>Clear GPT3</b>               |
| A21100A8 | <u>GPT3 CLK</u>     | 32           | <b>GPT3 clock setting</b>       |
| A21100AC | <u>GPT3 IRQ EN</u>  | 32           | <b>GPT3 IRQ enable</b>          |
| A21100B0 | <u>GPT3 IRQ STA</u> | 32           | <b>GPT3 IRQ status</b>          |
| A21100B4 | <u>GPT3 IRQ ACK</u> | 32           | <b>GPT3 IRQ acknowledgement</b> |
| A21100B8 | <u>GPT3 COUNT</u>   | 32           | <b>GPT3 counter value</b>       |
| A21100BC | <u>GPT3 COMPARE</u> | 32           | <b>GPT3 compare value</b>       |
| A21100D0 | <u>GPT4 CON</u>     | 32           | <b>GPT4 control</b>             |
| A21100D4 | <u>GPT4 CLR</u>     | 32           | <b>Clear GPT4</b>               |
| A21100D8 | <u>GPT4 CLK</u>     | 32           | <b>GPT4 clock setting</b>       |
| A21100DC | <u>GPT4 IRQ EN</u>  | 32           | <b>GPT4 IRQ enable</b>          |

| Address  | Name                 | Width (bits) | Register Functionality                |
|----------|----------------------|--------------|---------------------------------------|
| A21100E0 | <u>GPT4 IRQ STA</u>  | 32           | <b>GPT4 IRQ status</b>                |
| A21100E4 | <u>GPT4 IRQ ACK</u>  | 32           | <b>GPT4 IRQ acknowledgement</b>       |
| A21100E8 | <u>GPT4 COUNT</u>    | 32           | <b>GPT4 counter value</b>             |
| A21100EC | <u>GPT4 COMPARE</u>  | 32           | <b>GPT4 compare value</b>             |
| A2110100 | <u>GPT5 CON</u>      | 32           | <b>GPT5 control</b>                   |
| A2110104 | <u>GPT5 CLR</u>      | 32           | <b>Clear GPT5</b>                     |
| A2110108 | <u>GPT5 CLK</u>      | 32           | <b>GPT5 clock setting</b>             |
| A211010C | <u>GPT5 IRQ EN</u>   | 32           | <b>GPT5 IRQ enable</b>                |
| A2110110 | <u>GPT5 IRQ STA</u>  | 32           | <b>GPT5 IRQ status</b>                |
| A2110114 | <u>GPT5 IRQ ACK</u>  | 32           | <b>GPT5 IRQ acknowledgement</b>       |
| A2110118 | <u>GPT5 COUNTL</u>   | 32           | <b>GPT5 lower word counter value</b>  |
| A211011C | <u>GPT5 COMPAREL</u> | 32           | <b>GPT5 lower word compare value</b>  |
| A2110120 | <u>GPT5 COUNTH</u>   | 32           | <b>GPT5 higher word counter value</b> |
| A2110124 | <u>GPT5 COMPAREH</u> | 32           | <b>GPT5 higher word compare value</b> |

| <b>A2110000 GPT IRQSTA</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>GPT IRQ Status</b> |               |   |           |   | <b>oooooooooooo</b> |   |   |   |   |
|----------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------|---------------|---|-----------|---|---------------------|---|---|---|---|
| <b>Bit</b>                 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                    |               |   |           |   |                     |   |   |   |   |
| <b>Name</b>                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |               |   |           |   |                     |   |   |   |   |
| <b>Type</b>                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |               |   |           |   |                     |   |   |   |   |
| <b>Reset</b>               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |               |   |           |   |                     |   |   |   |   |
| <b>Bit</b>                 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                     |               |   |           |   |                     |   |   |   |   |
| <b>Name</b>                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       | <b>IRQSTA</b> |   |           |   |                     |   |   |   |   |
| <b>Type</b>                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |               |   | <b>RO</b> |   |                     |   |   |   |   |
| <b>Reset</b>               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       | 0             | 0 | 0         | 0 | 0                   | 0 | 0 | 0 | 0 |

| Bit(s) | Name   | Description                                                                                                              |
|--------|--------|--------------------------------------------------------------------------------------------------------------------------|
| 5:0    | IRQSTA | <b>Interrupt status of each GPT</b><br>0: No interrupt is generated.<br>1: Interrupt is pending and waiting for service. |

| <b>A2110010 GPTo CON</b> |    |    |    |    |    |    |    |    |              |    |    |    |    |    |    | <b>GPTo Control</b> |               |  |  |  | <b>00010000</b> |  |  |            |           |
|--------------------------|----|----|----|----|----|----|----|----|--------------|----|----|----|----|----|----|---------------------|---------------|--|--|--|-----------------|--|--|------------|-----------|
| <b>Bit</b>               | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23           | 22 | 21 | 20 | 19 | 18 | 17 | 16                  |               |  |  |  |                 |  |  |            |           |
| <b>Name</b>              |    |    |    |    |    |    |    |    |              |    |    |    |    |    |    |                     | <b>SW_CGo</b> |  |  |  |                 |  |  |            |           |
| <b>Type</b>              |    |    |    |    |    |    |    |    |              |    |    |    |    |    |    |                     |               |  |  |  |                 |  |  |            | <b>RW</b> |
| <b>Reset</b>             |    |    |    |    |    |    |    |    |              |    |    |    |    |    |    |                     |               |  |  |  |                 |  |  |            | 1         |
| <b>Bit</b>               | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7            | 6  | 5  | 4  | 3  | 2  | 1  | 0                   |               |  |  |  |                 |  |  |            |           |
| <b>Name</b>              |    |    |    |    |    |    |    |    | <b>MODEo</b> |    |    |    |    |    |    |                     |               |  |  |  |                 |  |  | <b>ENO</b> |           |
| <b>Type</b>              |    |    |    |    |    |    |    |    | <b>RW</b>    |    |    |    |    |    |    |                     |               |  |  |  |                 |  |  |            | <b>RW</b> |
| <b>Reset</b>             |    |    |    |    |    |    |    |    | 0            | 0  |    |    |    |    |    |                     |               |  |  |  |                 |  |  |            | 0         |

| Bit(s) | Name   | Description                                             |
|--------|--------|---------------------------------------------------------|
| 16     | SW_CGo | <b>Enable clock for GPTo</b><br>0: Enable<br>1: Disable |

|     |       |                               |
|-----|-------|-------------------------------|
| 9:8 | MODE0 | <b>Operation mode of GPTo</b> |
|     |       | 00: ONE-SHOT                  |
|     |       | 01: REPEAT                    |
|     |       | 10: FREERUN_I                 |
|     |       | 11: FREERUN                   |
| 0   | ENo   | <b>Enable GPTo</b>            |
|     |       | 0: Disable                    |
|     |       | 1: Enable                     |

| <b>A2110014 GPTo CLR</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>Clear GPTo</b> |             |  |  |
|--------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------|-------------|--|--|
| <b>Bit</b>               | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                |             |  |  |
| <b>Name</b>              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |             |  |  |
| <b>Type</b>              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |             |  |  |
| <b>Reset</b>             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |             |  |  |
| <b>Bit</b>               | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                 |             |  |  |
| <b>Name</b>              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   | <b>CLRo</b> |  |  |
| <b>Type</b>              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   | <b>WO</b>   |  |  |
| <b>Reset</b>             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   | 0           |  |  |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>       |
|---------------|-------------|--------------------------|
| 0             | CLRo        | <b>Clear GPTo</b>        |
|               |             | 0: No effect<br>1: Clear |

| <b>A2110018 GPTo CLK</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>GPTo Clock Setting</b> |             |  |  |
|--------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------------|-------------|--|--|
| <b>Bit</b>               | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                        |             |  |  |
| <b>Name</b>              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           |             |  |  |
| <b>Type</b>              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           |             |  |  |
| <b>Reset</b>             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           |             |  |  |
| <b>Bit</b>               | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                         |             |  |  |
| <b>Name</b>              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           | <b>CLKo</b> |  |  |
| <b>Type</b>              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           | <b>RW</b>   |  |  |
| <b>Reset</b>             |    |    |    |    |    |    |    |    |    |    |    |    | 0  | 0  | 0  | 0                         | 0           |  |  |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                                        |
|---------------|-------------|---------------------------------------------------------------------------|
| 4:0           | CLKo        | <b>Clock source and clock divider for GPTo</b>                            |
|               |             | Bit[4] - Clock source:<br>0: System clock (13MHz)<br>1: RTC clock (32kHz) |

Bit[3:0] - Clock divider:  
 0000: Clock source divided by 1  
 0001: Clock source divided by 2  
 0010: Clock source divided by 3  
 0011: Clock source divided by 4  
 0100: Clock source divided by 5  
 0101: Clock source divided by 6  
 0110: Clock source divided by 7  
 0111: Clock source divided by 8  
 1000: Clock source divided by 9  
 1001: Clock source divided by 10  
 1010: Clock source divided by 11  
 1011: Clock source divided by 12  
 1100: Clock source divided by 13  
 1101: Clock source divided by 16  
 1110: Clock source divided by 32  
 1111: Clock source divided by 64

| <b>A211001C GPTo IRQ_EN</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>GPTo IRQ Enable</b> |    |  |  | <b>oooooooooooo</b> |  |  |  |  |
|-----------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------------|----|--|--|---------------------|--|--|--|--|
| <b>Bit</b>                  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                     |    |  |  |                     |  |  |  |  |
| <b>Name</b>                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                        |    |  |  |                     |  |  |  |  |
| <b>Type</b>                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                        |    |  |  |                     |  |  |  |  |
| <b>Reset</b>                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                        |    |  |  |                     |  |  |  |  |
| <b>Bit</b>                  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                      |    |  |  |                     |  |  |  |  |
| <b>Name</b>                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | IRQENo                 | No |  |  |                     |  |  |  |  |
| <b>Type</b>                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW                     |    |  |  |                     |  |  |  |  |
| <b>Reset</b>                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0                      |    |  |  |                     |  |  |  |  |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                         |
|---------------|-------------|------------------------------------------------------------|
| 0             | IRQENO      | <b>Enable interrupt of GPTo</b><br>0: Disable<br>1: Enable |
|               |             |                                                            |

| <b>A2110020 GPTo IRQ_STA</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>GPTo IRQ Status</b> |         |  |  | <b>oooooooooooo</b> |  |  |  |  |
|------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------------|---------|--|--|---------------------|--|--|--|--|
| <b>Bit</b>                   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                     |         |  |  |                     |  |  |  |  |
| <b>Name</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                        |         |  |  |                     |  |  |  |  |
| <b>Type</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                        |         |  |  |                     |  |  |  |  |
| <b>Reset</b>                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                        |         |  |  |                     |  |  |  |  |
| <b>Bit</b>                   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                      | IRQSTAo |  |  |                     |  |  |  |  |
| <b>Name</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | IRQSTAo                |         |  |  |                     |  |  |  |  |
| <b>Type</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RO                     |         |  |  |                     |  |  |  |  |
| <b>Reset</b>                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0                      |         |  |  |                     |  |  |  |  |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>              |
|---------------|-------------|---------------------------------|
| 0             | IRQSTAo     | <b>Interrupt status of GPTo</b> |

0: No interrupt is generated  
1: Interrupt is pending and waiting for service

**A2110024 GPTo IRQ ACK      GPTo IRQ Acknowledgement      00000000**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16      |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0       |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | IRQACKO |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | WO      |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0       |

| Bit(s) | Name    | Description                                                                                                   |
|--------|---------|---------------------------------------------------------------------------------------------------------------|
| 0      | IRQACKO | Interrupt acknowledgement for GPTo<br>0: No effect<br>1: Interrupt is acknowledged and should be relinquished |

**A2110028 GPTo COUNT      GPTo Counter Value      00000000**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16       |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0        |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0        |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | COUNTERO |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RO       |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0        |

| Bit(s) | Name     | Description           |
|--------|----------|-----------------------|
| 31:0   | COUNTERO | Counter value of GPTo |

**A211002C GPTo\_COMPARE      GPTo Compare Value      FFFFFFFF**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16       |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |
| Reset | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1        |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0        |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | COMPAREO |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW       |
| Reset | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1        |

| Bit(s) | Name     | Description           |
|--------|----------|-----------------------|
| 31:0   | COMPAREO | Compare value of GPTo |

**A2110040 GPT1 CON      GPT1 Control      00010000**

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

|       |    |    |    |    |    |    |              |   |   |   |   |   |   |   |    |     |
|-------|----|----|----|----|----|----|--------------|---|---|---|---|---|---|---|----|-----|
| Type  |    |    |    |    |    |    |              |   |   |   |   |   |   |   | RW |     |
| Reset |    |    |    |    |    |    |              |   |   |   |   |   |   |   | 1  |     |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9            | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1  | 0   |
| Name  |    |    |    |    |    |    | <b>MODE1</b> |   |   |   |   |   |   |   |    | EN1 |
| Type  |    |    |    |    |    |    | RW           |   |   |   |   |   |   |   |    | RW  |
| Reset |    |    |    |    |    |    | 0            | 0 |   |   |   |   |   |   |    | 0   |

| Bit(s) | Name   | Description                                                                                 |
|--------|--------|---------------------------------------------------------------------------------------------|
| 16     | SW_CG1 | <b>Enable clock for GPT1</b><br>0: Enable<br>1: Disable                                     |
| 9:8    | MODE1  | <b>Operation mode of GPT1</b><br>00: ONE-SHOT<br>01: REPEAT<br>10: FREERUN_I<br>11: FREERUN |
| 0      | EN1    | <b>Enable GPT1</b><br>0: Disable<br>1: Enable                                               |

| A2110044 GPT1 CLR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Clear GPT1 |  |  |  | 00000000 |  |  |  |      |
|-------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|--|--|--|----------|--|--|--|------|
| Bit               | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16         |  |  |  |          |  |  |  |      |
| Name              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |  |  |  |          |  |  |  |      |
| Type              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |  |  |  |          |  |  |  |      |
| Reset             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |  |  |  |          |  |  |  |      |
| Bit               | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0          |  |  |  |          |  |  |  |      |
| Name              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |  |  |  |          |  |  |  | CLR1 |
| Type              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |  |  |  |          |  |  |  | WO   |
| Reset             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |  |  |  |          |  |  |  | 0    |

| Bit(s) | Name | Description                                   |
|--------|------|-----------------------------------------------|
| 0      | CLR1 | <b>Clear GPT1</b><br>0: No effect<br>1: Clear |

| A2110048 GPT1 CLK |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | GPT1 Clock Setting |             |   |   | 00000000 |   |   |  |  |
|-------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------|-------------|---|---|----------|---|---|--|--|
| Bit               | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                 |             |   |   |          |   |   |  |  |
| Name              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    |             |   |   |          |   |   |  |  |
| Type              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    |             |   |   |          |   |   |  |  |
| Reset             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    |             |   |   |          |   |   |  |  |
| Bit               | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                  |             |   |   |          |   |   |  |  |
| Name              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    | <b>CLK1</b> |   |   |          |   |   |  |  |
| Type              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    | RW          |   |   |          |   |   |  |  |
| Reset             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    | 0           | 0 | 0 | 0        | 0 | 0 |  |  |

| Bit(s) | Name | Description                                      |
|--------|------|--------------------------------------------------|
| 4:0    | CLK1 | <b>Clock source &amp; clock divider for GPT1</b> |

Bit[4] - Clock source:

0: System clock (13MHz)

1: RTC clock (32kHz)

Bit[3:0] - Clock divider:

0000: Clock source divided by 1

0001: Clock source divided by 2

0010: Clock source divided by 3

0011: Clock source divided by 4

0100: Clock source divided by 5

0101: Clock source divided by 6

0110: Clock source divided by 7

0111: Clock source divided by 8

1000: Clock source divided by 9

1001: Clock source divided by 10

1010: Clock source divided by 11

1011: Clock source divided by 12

1100: Clock source divided by 13

1101: Clock source divided by 16

1110: Clock source divided by 32

1111: Clock source divided by 64

#### A211004C GPT1 IRQ EN

#### GPT1 IRQ Enable

#### oooooooooooo

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16      |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0       |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | IRQE N1 |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW      |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0       |

#### Bit(s) Name

#### Description

0      IRQEN1      Enable interrupt of GPT1

0: Disable

1: Enable

#### A2110050 GPT1 IRQ STA

#### GPT1 IRQ Status

#### oooooooooooo

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16      |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0       |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | IRQSTA1 |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RO      |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0       |

#### Bit(s) Name

#### Description

---

|   |         |                                                  |
|---|---------|--------------------------------------------------|
| 0 | IRQSTA1 | <b>Interrupt status of GPT1</b>                  |
|   |         | 0: No interrupt is generated.                    |
|   |         | 1: Interrupt is pending and waiting for service. |

---

| <b>A2110054 GPT1 IRQ ACK</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>GPT1 IRQ Acknowledgement</b> |                |  |  |
|------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------------------|----------------|--|--|
| <b>Bit</b>                   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                              |                |  |  |
| <b>Name</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                 |                |  |  |
| <b>Type</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                 |                |  |  |
| <b>Reset</b>                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                 |                |  |  |
| <b>Bit</b>                   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                               |                |  |  |
| <b>Name</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                 | <b>IRQACK1</b> |  |  |
| <b>Type</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                 | WO             |  |  |
| <b>Reset</b>                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                 | 0              |  |  |

---

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                      |
|---------------|-------------|---------------------------------------------------------|
| 0             | IRQACK1     | <b>Interrupt acknowledgement for GPT1</b>               |
|               |             | 0: No effect                                            |
|               |             | 1: Interrupt is acknowledged and should be relinquished |

---

| <b>A2110058 GPT1 COUNT</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>GPT1 Counter Value</b> |                 |  |  |
|----------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------------|-----------------|--|--|
| <b>Bit</b>                 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                        |                 |  |  |
| <b>Name</b>                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           | <b>COUNTER1</b> |  |  |
| <b>Type</b>                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           | RO              |  |  |
| <b>Reset</b>               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                         | 0               |  |  |
| <b>Bit</b>                 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                         |                 |  |  |
| <b>Name</b>                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           | <b>COUNTER1</b> |  |  |
| <b>Type</b>                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           | RO              |  |  |
| <b>Reset</b>               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                         | 0               |  |  |

---

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>    |
|---------------|-------------|-----------------------|
| 31:0          | COUNTER1    | Counter value of GPT1 |

---

| <b>A211005C GPT1 COMPARE</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>GPT1 Compare Value</b> |                 |  |  |
|------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------------|-----------------|--|--|
| <b>Bit</b>                   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                        |                 |  |  |
| <b>Name</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           | <b>COMPARE1</b> |  |  |
| <b>Type</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           | RW              |  |  |
| <b>Reset</b>                 | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1                         | 1               |  |  |
| <b>Bit</b>                   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                         |                 |  |  |
| <b>Name</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           | <b>COMPARE1</b> |  |  |
| <b>Type</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           | RW              |  |  |
| <b>Reset</b>                 | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1                         | 1               |  |  |

---

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>    |
|---------------|-------------|-----------------------|
| 31:0          | COMPARE1    | Compare value of GPT1 |

---

| <b>A2110070 GPT2 CON</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>GPT2 Control</b> |            |  |  |
|--------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------|------------|--|--|
| <b>Bit</b>               | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                  |            |  |  |
| <b>Name</b>              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                     | <b>SW_</b> |  |  |

|              |              |    |    |    |    |    |   |   |   |   |   |   |   |   |   |            |
|--------------|--------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------------|
| <b>Type</b>  |              |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>CG2</b> |
| <b>Reset</b> |              |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW         |
| <b>Bit</b>   | 15           | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0          |
| <b>Name</b>  | <b>MODE2</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>EN2</b> |
| <b>Type</b>  | RW           |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW         |
| <b>Reset</b> | 0 0          |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0          |

| Bit(s) | Name   | Description                                                                                 |
|--------|--------|---------------------------------------------------------------------------------------------|
| 16     | SW_CG2 | <b>Enable clock for GPT2</b><br>0: Enable<br>1: Disable                                     |
| 9:8    | MODE2  | <b>Operation mode of GPT2</b><br>00: ONE-SHOT<br>01: REPEAT<br>10: FREERUN_I<br>11: FREERUN |
| 0      | EN2    | <b>Enable GPT2</b><br>0: Disable<br>1: Enable                                               |

| A2110074 GPT2 CLR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Clear GPT2 |          |             |  |  |
|-------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|----------|-------------|--|--|
| <b>Bit</b>        | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16         | 00000000 |             |  |  |
| <b>Name</b>       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |          |             |  |  |
| <b>Type</b>       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |          |             |  |  |
| <b>Reset</b>      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |          |             |  |  |
| <b>Bit</b>        | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0          |          |             |  |  |
| <b>Name</b>       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |          | <b>CLR2</b> |  |  |
| <b>Type</b>       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |          | WO          |  |  |
| <b>Reset</b>      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |          | 0           |  |  |

| Bit(s) | Name | Description                                   |
|--------|------|-----------------------------------------------|
| 0      | CLR2 | <b>Clear GPT2</b><br>0: No effect<br>1: Clear |

| A2110078 GPT2 CLK |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | GPT2 Clock Setting |             |   |   |  |
|-------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------|-------------|---|---|--|
| <b>Bit</b>        | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                 | 00000000    |   |   |  |
| <b>Name</b>       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    |             |   |   |  |
| <b>Type</b>       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    |             |   |   |  |
| <b>Reset</b>      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    |             |   |   |  |
| <b>Bit</b>        | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                  |             |   |   |  |
| <b>Name</b>       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    | <b>CLK2</b> |   |   |  |
| <b>Type</b>       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    | RW          |   |   |  |
| <b>Reset</b>      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    | 0           | 0 | 0 |  |

| Bit(s) | Name | Description                                      |
|--------|------|--------------------------------------------------|
| 4:0    | CLK2 | <b>Clock source &amp; clock divider for GPT2</b> |

Bit[4] - Clock source:

0: System clock (13MHz)

1: RTC clock (32KHz)

Bit[3:0] - Clock divider:

0000: Clock source divided by 1

0001: Clock source divided by 2

0010: Clock source divided by 3

0011: Clock source divided by 4

0100: Clock source divided by 5

0101: Clock source divided by 6

0110: Clock source divided by 7

0111: Clock source divided by 8

1000: Clock source divided by 9

1001: Clock source divided by 10

1010: Clock source divided by 11

1011: Clock source divided by 12

1100: Clock source divided by 13

1101: Clock source divided by 16

1110: Clock source divided by 32

1111: Clock source divided by 64

### A211007C GPT2 IRQ EN

### GPT2 IRQ Enable

### oooooooooooo

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16      |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0       |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | IRQE N2 |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW      |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0       |

### Bit(s) Name

### Description

0 IRQEN2 Enable interrupt of GPT2

0: Disable

1: Enable

### A2110080 GPT2 IRQ STA

### GPT2 IRQ Status

### oooooooooooo

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16       |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0        |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | IRQS TA2 |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RO       |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0        |

### Bit(s) Name

### Description

---

|   |         |                                                  |
|---|---------|--------------------------------------------------|
| 0 | IRQSTA2 | <b>Interrupt status of GPT2</b>                  |
|   |         | 0: No interrupt is generated.                    |
|   |         | 1: Interrupt is pending and waiting for service. |

---

| <b>A2110084 GPT2 IRQ ACK</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>GPT2 IRQ Acknowledgement</b> |                |  |  |
|------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------------------|----------------|--|--|
| <b>Bit</b>                   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                              |                |  |  |
| <b>Name</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                 |                |  |  |
| <b>Type</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                 |                |  |  |
| <b>Reset</b>                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                 |                |  |  |
| <b>Bit</b>                   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                               |                |  |  |
| <b>Name</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                 | <b>IRQACK2</b> |  |  |
| <b>Type</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                 | WO             |  |  |
| <b>Reset</b>                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                 | 0              |  |  |

---

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                      |
|---------------|-------------|---------------------------------------------------------|
| 0             | IRQACK2     | <b>Interrupt acknowledgement for GPT2</b>               |
|               |             | 0: No effect                                            |
|               |             | 1: Interrupt is acknowledged and should be relinquished |

---

| <b>A2110088 GPT2 COUNT</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>GPT2 Counter Value</b> |                 |  |  |
|----------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------------|-----------------|--|--|
| <b>Bit</b>                 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                        |                 |  |  |
| <b>Name</b>                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           | <b>COUNTER2</b> |  |  |
| <b>Type</b>                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           | RO              |  |  |
| <b>Reset</b>               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                         | 0               |  |  |
| <b>Bit</b>                 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                         |                 |  |  |
| <b>Name</b>                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           | <b>COUNTER2</b> |  |  |
| <b>Type</b>                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           | RO              |  |  |
| <b>Reset</b>               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                         | 0               |  |  |

---

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>    |
|---------------|-------------|-----------------------|
| 31:0          | COUNTER2    | Counter value of GPT2 |

---

| <b>A211008C GPT2 COMPARE</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>GPT2 Compare Value</b> |                 |  |  |
|------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------------|-----------------|--|--|
| <b>Bit</b>                   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                        |                 |  |  |
| <b>Name</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           | <b>COMPARE2</b> |  |  |
| <b>Type</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           | RW              |  |  |
| <b>Reset</b>                 | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1                         | 1               |  |  |
| <b>Bit</b>                   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                         |                 |  |  |
| <b>Name</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           | <b>COMPARE2</b> |  |  |
| <b>Type</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           | RW              |  |  |
| <b>Reset</b>                 | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1                         | 1               |  |  |

---

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>    |
|---------------|-------------|-----------------------|
| 31:0          | COMPARE2    | Compare value of GPT2 |

---

| <b>A21100A0 GPT3 CON</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>GPT3 Control</b> |            |  |  |
|--------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------|------------|--|--|
| <b>Bit</b>               | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                  |            |  |  |
| <b>Name</b>              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                     | <b>SW_</b> |  |  |

|              |    |    |    |    |    |    |              |   |   |   |   |   |   |   |   |            |
|--------------|----|----|----|----|----|----|--------------|---|---|---|---|---|---|---|---|------------|
| <b>Type</b>  |    |    |    |    |    |    |              |   |   |   |   |   |   |   |   | <b>CG3</b> |
| <b>Reset</b> |    |    |    |    |    |    |              |   |   |   |   |   |   |   |   | RW         |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9            | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0          |
| <b>Name</b>  |    |    |    |    |    |    | <b>MODE3</b> |   |   |   |   |   |   |   |   | <b>EN3</b> |
| <b>Type</b>  |    |    |    |    |    |    | RW           |   |   |   |   |   |   |   |   | RW         |
| <b>Reset</b> |    |    |    |    |    |    | 0            | 0 |   |   |   |   |   |   |   | 0          |

| Bit(s) | Name   | Description                                                                                 |
|--------|--------|---------------------------------------------------------------------------------------------|
| 16     | SW_CG3 | <b>Enable clock for GPT3</b><br>0: Enable<br>1: Disable                                     |
| 9:8    | MODE3  | <b>Operation mode of GPT3</b><br>00: ONE-SHOT<br>01: REPEAT<br>10: FREERUN_I<br>11: FREERUN |
| 0      | EN3    | <b>Enable GPT3</b><br>0: Disable<br>1: Enable                                               |

| A21100A4 GPT3 CLR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Clear GPT3 |             |  |  |
|-------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|-------------|--|--|
| <b>Bit</b>        | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16         |             |  |  |
| <b>Name</b>       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |             |  |  |
| <b>Type</b>       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |             |  |  |
| <b>Reset</b>      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |             |  |  |
| <b>Bit</b>        | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0          |             |  |  |
| <b>Name</b>       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            | <b>CLR3</b> |  |  |
| <b>Type</b>       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            | WO          |  |  |
| <b>Reset</b>      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            | 0           |  |  |

| Bit(s) | Name | Description                                   |
|--------|------|-----------------------------------------------|
| 0      | CLR3 | <b>Clear GPT3</b><br>0: No effect<br>1: Clear |

| A21100A8 GPT3 CLK |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | GPT3 Clock Setting |             |  |  |
|-------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------|-------------|--|--|
| <b>Bit</b>        | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                 |             |  |  |
| <b>Name</b>       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    |             |  |  |
| <b>Type</b>       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    |             |  |  |
| <b>Reset</b>      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    |             |  |  |
| <b>Bit</b>        | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                  |             |  |  |
| <b>Name</b>       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    | <b>CLK3</b> |  |  |
| <b>Type</b>       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    | RW          |  |  |
| <b>Reset</b>      |    |    |    |    |    |    |    |    |    |    |    |    | 0  | 0  | 0  | 0                  | 0           |  |  |

| Bit(s) | Name | Description                                    |
|--------|------|------------------------------------------------|
| 4:0    | CLK3 | <b>Clock source and clock divider for GPT3</b> |

Bit[4] - Clock source:

0: System clock (13MHz)

1: RTC clock (32KHz)

Bit[3:0] - Clock divider:

0000: Clock source divided by 1

0001: Clock source divided by 2

0010: Clock source divided by 3

0011: Clock source divided by 4

0100: Clock source divided by 5

0101: Clock source divided by 6

0110: Clock source divided by 7

0111: Clock source divided by 8

1000: Clock source divided by 9

1001: Clock source divided by 10

1010: Clock source divided by 11

1011: Clock source divided by 12

1100: Clock source divided by 13

1101: Clock source divided by 16

1110: Clock source divided by 32

1111: Clock source divided by 64

#### A21100AC GPT3 IRQ EN

#### GPT3 IRQ Enable

#### oooooooooooo

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16         |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0          |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | IRQE<br>N3 |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW         |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0          |

#### Bit(s) Name

#### Description

0 IRQEN3 Enable interrupt of GPT3

0: Disable

1: Enable

#### A21100Bo GPT3 IRQ STA

#### GPT3 IRQ Status

#### oooooooooooo

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16          |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |             |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |             |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |             |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0           |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | IRQS<br>TA3 |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RO          |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0           |

#### Bit(s) Name

#### Description

|   |         |                                                 |
|---|---------|-------------------------------------------------|
| 0 | IRQSTA3 | <b>Interrupt status of GPT3</b>                 |
|   |         | 0: No interrupt is generated                    |
|   |         | 1: Interrupt is pending and waiting for service |

| <b>A21100B4 GPT3 IRQ ACK</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>GPT3 IRQ Acknowledgement</b> |                |  |  |
|------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------------------|----------------|--|--|
| <b>Bit</b>                   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                              |                |  |  |
| <b>Name</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                 |                |  |  |
| <b>Type</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                 |                |  |  |
| <b>Reset</b>                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                 |                |  |  |
| <b>Bit</b>                   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                               |                |  |  |
| <b>Name</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                 | <b>IRQACK3</b> |  |  |
| <b>Type</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                 | WO             |  |  |
| <b>Reset</b>                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                 | 0              |  |  |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                      |
|---------------|-------------|---------------------------------------------------------|
| 0             | IRQACK3     | <b>Interrupt acknowledgement for GPT3</b>               |
|               |             | 0: No effect                                            |
|               |             | 1: Interrupt is acknowledged and should be relinquished |

| <b>A21100B8 GPT3 COUNT</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>GPT3 Counter Value</b> |                 |  |  |
|----------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------------|-----------------|--|--|
| <b>Bit</b>                 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                        |                 |  |  |
| <b>Name</b>                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           | <b>COUNTER3</b> |  |  |
| <b>Type</b>                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           | RO              |  |  |
| <b>Reset</b>               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                         | 0               |  |  |
| <b>Bit</b>                 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                         |                 |  |  |
| <b>Name</b>                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           | <b>COUNTER3</b> |  |  |
| <b>Type</b>                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           | RO              |  |  |
| <b>Reset</b>               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                         | 0               |  |  |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>    |
|---------------|-------------|-----------------------|
| 31:0          | COUNTER3    | Counter value of GPT3 |

| <b>A21100BC GPT3 COMPARE</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>GPT3 Compare Value</b> |                 |  |  |
|------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------------|-----------------|--|--|
| <b>Bit</b>                   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                        |                 |  |  |
| <b>Name</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           | <b>COMPARE3</b> |  |  |
| <b>Type</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           | RW              |  |  |
| <b>Reset</b>                 | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1                         | 1               |  |  |
| <b>Bit</b>                   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                         |                 |  |  |
| <b>Name</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           | <b>COMPARE3</b> |  |  |
| <b>Type</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           | RW              |  |  |
| <b>Reset</b>                 | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1                         | 1               |  |  |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>    |
|---------------|-------------|-----------------------|
| 31:0          | COMPARE3    | Compare value of GPT3 |

| <b>A21100Do GPT4 CON</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>GPT4 Control</b> |            |  |  |
|--------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------|------------|--|--|
| <b>Bit</b>               | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                  |            |  |  |
| <b>Name</b>              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                     | <b>SW_</b> |  |  |

|       |    |    |    |    |    |    |       |   |   |   |   |   |   |   |   |     |
|-------|----|----|----|----|----|----|-------|---|---|---|---|---|---|---|---|-----|
| Type  |    |    |    |    |    |    |       |   |   |   |   |   |   |   |   | CG4 |
| Reset |    |    |    |    |    |    |       |   |   |   |   |   |   |   |   | RW  |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9     | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0   |
| Name  |    |    |    |    |    |    | MODE4 |   |   |   |   |   |   |   |   | EN4 |
| Type  |    |    |    |    |    |    | RW    |   |   |   |   |   |   |   |   | RW  |
| Reset |    |    |    |    |    |    | 0     | 0 |   |   |   |   |   |   |   | 0   |

| Bit(s) | Name   | Description                                                                                 |
|--------|--------|---------------------------------------------------------------------------------------------|
| 16     | SW_CG4 | <b>Enable clock for GPT4</b><br>0: Enable<br>1: Disable                                     |
| 9:8    | MODE4  | <b>Operation mode of GPT4</b><br>00: ONE-SHOT<br>01: REPEAT<br>10: FREERUN_I<br>11: FREERUN |
| 0      | EN4    | <b>Enable GPT4</b><br>0: Disable<br>1: Enable                                               |

| A21100D4 GPT4 CLR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Clear GPT4 |          |  |  |  |
|-------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|----------|--|--|--|
| Bit               | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16         | 00000000 |  |  |  |
| Name              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |          |  |  |  |
| Type              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |          |  |  |  |
| Reset             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |          |  |  |  |
| Bit               | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0          |          |  |  |  |
| Name              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            | CLR4     |  |  |  |
| Type              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            | WO       |  |  |  |
| Reset             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            | 0        |  |  |  |

| Bit(s) | Name | Description                                   |
|--------|------|-----------------------------------------------|
| 0      | CLR4 | <b>Clear GPT4</b><br>0: No effect<br>1: Clear |

| A21100D8 GPT4 CLK |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | GPT4 Clock Setting |          |   |   |  |
|-------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------|----------|---|---|--|
| Bit               | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                 | 00000000 |   |   |  |
| Name              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    |          |   |   |  |
| Type              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    |          |   |   |  |
| Reset             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    |          |   |   |  |
| Bit               | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                  |          |   |   |  |
| Name              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    | CLK4     |   |   |  |
| Type              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    | RW       |   |   |  |
| Reset             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    | 0        | 0 | 0 |  |

| Bit(s) | Name | Description                                    |
|--------|------|------------------------------------------------|
| 4:0    | CLK4 | <b>Clock source and clock divider for GPT4</b> |

Bit[4] - Clock source:

0: System clock (13MHz)

1: RTC clock (32KHz)

Bit[3:0] - Clock divider:

0000: Clock source divided by 1

0001: Clock source divided by 2

0010: Clock source divided by 3

0011: Clock source divided by 4

0100: Clock source divided by 5

0101: Clock source divided by 6

0110: Clock source divided by 7

0111: Clock source divided by 8

1000: Clock source divided by 9

1001: Clock source divided by 10

1010: Clock source divided by 11

1011: Clock source divided by 12

1100: Clock source divided by 13

1101: Clock source divided by 16

1110: Clock source divided by 32

1111: Clock source divided by 64

#### A21100DC GPT4 IRQ EN

#### GPT4 IRQ Enable

#### oooooooooooo

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16      |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |         |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0       |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | IRQE N4 |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW      |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0       |

#### Bit(s) Name

#### Description

0      IRQEN4      Enable interrupt of GPT4

0: Disable

1: Enable

#### A21100Eo GPT4 IRQ STA

#### GPT4 IRQ Status

#### oooooooooooo

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16       |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0        |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | IRQS TA4 |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RO       |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0        |

#### Bit(s) Name

#### Description

---

|   |         |                                                 |
|---|---------|-------------------------------------------------|
| 0 | IRQSTA4 | <b>Interrupt status of GPT4</b>                 |
|   |         | 0: No interrupt is generated                    |
|   |         | 1: Interrupt is pending and waiting for service |

---

| <b>A21100E4 GPT4 IRQ ACK</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>GPT4 IRQ Acknowledgement</b> |                |  |  |
|------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------------------|----------------|--|--|
| <b>Bit</b>                   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                              |                |  |  |
| <b>Name</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                 |                |  |  |
| <b>Type</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                 |                |  |  |
| <b>Reset</b>                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                 |                |  |  |
| <b>Bit</b>                   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                               |                |  |  |
| <b>Name</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                 | <b>IRQACK4</b> |  |  |
| <b>Type</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                 | WO             |  |  |
| <b>Reset</b>                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                 | 0              |  |  |

---

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                      |
|---------------|-------------|---------------------------------------------------------|
| 0             | IRQACK4     | <b>Interrupt acknowledgement for GPT4</b>               |
|               |             | 0: No effect                                            |
|               |             | 1: Interrupt is acknowledged and should be relinquished |

---

| <b>A21100E8 GPT4 COUNT</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>GPT4 Counter Value</b> |                 |  |  |
|----------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------------|-----------------|--|--|
| <b>Bit</b>                 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                        |                 |  |  |
| <b>Name</b>                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           | <b>COUNTER4</b> |  |  |
| <b>Type</b>                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           | RO              |  |  |
| <b>Reset</b>               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                         | 0               |  |  |
| <b>Bit</b>                 | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                         |                 |  |  |
| <b>Name</b>                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           | <b>COUNTER4</b> |  |  |
| <b>Type</b>                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           | RO              |  |  |
| <b>Reset</b>               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                         | 0               |  |  |

---

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>    |
|---------------|-------------|-----------------------|
| 31:0          | COUNTER4    | Counter value of GPT4 |

---

| <b>A21100EC GPT4 COMPARE</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>GPT4 Compare Value</b> |                 |  |  |
|------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------------|-----------------|--|--|
| <b>Bit</b>                   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                        |                 |  |  |
| <b>Name</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           | <b>COMPARE4</b> |  |  |
| <b>Type</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           | RW              |  |  |
| <b>Reset</b>                 | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1                         | 1               |  |  |
| <b>Bit</b>                   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                         |                 |  |  |
| <b>Name</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           | <b>COMPARE4</b> |  |  |
| <b>Type</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           | RW              |  |  |
| <b>Reset</b>                 | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1                         | 1               |  |  |

---

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>    |
|---------------|-------------|-----------------------|
| 31:0          | COMPARE4    | Compare value of GPT4 |

---

| <b>A2110100 GPT5 CON</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>GPT5 Control</b> |            |  |  |
|--------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------|------------|--|--|
| <b>Bit</b>               | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                  |            |  |  |
| <b>Name</b>              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                     | <b>SW_</b> |  |  |

|       |    |    |    |    |    |    |       |   |   |   |   |   |   |   |   |     |
|-------|----|----|----|----|----|----|-------|---|---|---|---|---|---|---|---|-----|
| Type  |    |    |    |    |    |    |       |   |   |   |   |   |   |   |   | CG5 |
| Reset |    |    |    |    |    |    |       |   |   |   |   |   |   |   |   | RW  |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9     | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0   |
| Name  |    |    |    |    |    |    | MODE5 |   |   |   |   |   |   |   |   | EN5 |
| Type  |    |    |    |    |    |    | RW    |   |   |   |   |   |   |   |   | RW  |
| Reset |    |    |    |    |    |    | 0     | 0 |   |   |   |   |   |   |   | 0   |

| Bit(s) | Name   | Description                                                                                 |
|--------|--------|---------------------------------------------------------------------------------------------|
| 16     | SW_CG5 | <b>Enable clock for GPT5</b><br>0: Enable<br>1: Disable                                     |
| 9:8    | MODE5  | <b>Operation mode of GPT5</b><br>00: ONE-SHOT<br>01: REPEAT<br>10: FREERUN_I<br>11: FREERUN |
| 0      | EN5    | <b>Enable GPT5</b><br>0: Disable<br>1: Enable                                               |

| A2110104 GPT5 CLR |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Clear GPT5 |      |  |  |
|-------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|------|--|--|
| Bit               | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16         |      |  |  |
| Name              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |      |  |  |
| Type              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |      |  |  |
| Reset             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |      |  |  |
| Bit               | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0          |      |  |  |
| Name              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            | CLR5 |  |  |
| Type              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            | WO   |  |  |
| Reset             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            | 0    |  |  |

| Bit(s) | Name | Description                                   |
|--------|------|-----------------------------------------------|
| 0      | CLR5 | <b>Clear GPT5</b><br>0: No effect<br>1: Clear |

| A2110108 GPT5 CLK |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | GPT5 Clock Setting |      |   |  |
|-------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------|------|---|--|
| Bit               | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                 |      |   |  |
| Name              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    |      |   |  |
| Type              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    |      |   |  |
| Reset             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    |      |   |  |
| Bit               | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                  |      |   |  |
| Name              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    | CLK5 |   |  |
| Type              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    | RW   |   |  |
| Reset             |    |    |    |    |    |    |    |    |    |    |    |    | 0  | 0  | 0  | 0                  | 0    | 0 |  |

| Bit(s) | Name | Description                                      |
|--------|------|--------------------------------------------------|
| 4:0    | CLK5 | <b>Clock source &amp; clock divider for GPT5</b> |

Bit[4] - Clock source:

0: System clock (13MHz)

1: RTC clock (32KHz)

Bit[3:0] - Clock divider:

0000: Clock source divided by 1

0001: Clock source divided by 2

0010: Clock source divided by 3

0011: Clock source divided by 4

0100: Clock source divided by 5

0101: Clock source divided by 6

0110: Clock source divided by 7

0111: Clock source divided by 8

1000: Clock source divided by 9

1001: Clock source divided by 10

1010: Clock source divided by 11

1011: Clock source divided by 12

1100: Clock source divided by 13

1101: Clock source divided by 16

1110: Clock source divided by 32

1111: Clock source divided by 64

### A211010C GPT5 IRQ EN

### GPT5 IRQ Enable

oooooooooooo

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16         |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |            |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0          |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | IRQE<br>N5 |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW         |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0          |

### Bit(s) Name

### Description

0 IRQEN5 Enable interrupt of GPT5

0: Disable

1: Enable

### A2110110 GPT5 IRQ STA

### GPT5 IRQ Status

oooooooooooo

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16          |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |             |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |             |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |             |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0           |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | IRQS<br>TA5 |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RO          |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0           |

### Bit(s) Name

### Description

---

|   |         |                                                  |
|---|---------|--------------------------------------------------|
| 0 | IRQSTA5 | <b>Interrupt status of GPT5</b>                  |
|   |         | 0: No interrupt is generated.                    |
|   |         | 1: Interrupt is pending and waiting for service. |

---

| <b>A2110114 GPT5 IRQ ACK</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>GPT5 IRQ Acknowledgement</b> |                |  |  |
|------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------------------|----------------|--|--|
| <b>Bit</b>                   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                              |                |  |  |
| <b>Name</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                 |                |  |  |
| <b>Type</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                 |                |  |  |
| <b>Reset</b>                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                 |                |  |  |
| <b>Bit</b>                   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                               |                |  |  |
| <b>Name</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                 | <b>IRQACK5</b> |  |  |
| <b>Type</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                 | WO             |  |  |
| <b>Reset</b>                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                 | 0              |  |  |

---

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                      |
|---------------|-------------|---------------------------------------------------------|
| 0             | IRQACK5     | <b>Interrupt acknowledgement for GPT5</b>               |
|               |             | 0: No effect                                            |
|               |             | 1: Interrupt is acknowledged and should be relinquished |

---

| <b>A2110118 GPT5 COUNTL</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>GPT5 Lower Word Counter Value</b> |                  |  |  |
|-----------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------------------------|------------------|--|--|
| <b>Bit</b>                  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                                   |                  |  |  |
| <b>Name</b>                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                      | <b>COUNTER5L</b> |  |  |
| <b>Type</b>                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                      | RO               |  |  |
| <b>Reset</b>                | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                                    | 0                |  |  |
| <b>Bit</b>                  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                                    |                  |  |  |
| <b>Name</b>                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                      | <b>COUNTER5L</b> |  |  |
| <b>Type</b>                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                      | RO               |  |  |
| <b>Reset</b>                | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                                    | 0                |  |  |

---

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>               |
|---------------|-------------|----------------------------------|
| 31:0          | COUNTER5L   | Lower word counter value of GPT5 |

---

| <b>A211011C GPT5 COMPARL</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>GPT5 Lower Word Compare Value</b> |                  |  |  |
|------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------------------------|------------------|--|--|
| <b>Bit</b>                   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                                   |                  |  |  |
| <b>Name</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                      | <b>COMPARE5L</b> |  |  |
| <b>Type</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                      | RW               |  |  |
| <b>Reset</b>                 | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1                                    | 1                |  |  |
| <b>Bit</b>                   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                                    |                  |  |  |
| <b>Name</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                      | <b>COMPARE5L</b> |  |  |
| <b>Type</b>                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                      | RW               |  |  |
| <b>Reset</b>                 | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1                                    | 1                |  |  |

---

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>               |
|---------------|-------------|----------------------------------|
| 31:0          | COMPARE5L   | Lower word compare value of GPT5 |

---

| <b>A2110120 GPT5 COUNTH</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>GPT5 Higher Word Counter Value</b> |                  |  |  |
|-----------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------------------------|------------------|--|--|
| <b>Bit</b>                  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                                    |                  |  |  |
| <b>Name</b>                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                                       | <b>COUNTER5H</b> |  |  |

| Type  | RO        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------|-----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Reset | 0         | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Bit   | 15        | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name  | COUNTER5H |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | RO        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0         | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| Bit(s) | Name      | Description                       |
|--------|-----------|-----------------------------------|
| 31:0   | COUNTER5H | Higher word counter value of GPT5 |

| A2110124 GPT5_COMPAREH GPT5 Higher WordCompare Value FFFFFFFF |           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|---------------------------------------------------------------|-----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit                                                           | 31        | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name                                                          | COMPARE5H |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                                                          | RW        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset                                                         | 1         | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  |
| Bit                                                           | 15        | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name                                                          | COMPARE5H |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                                                          | RW        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset                                                         | 1         | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  |

| Bit(s) | Name      | Description                       |
|--------|-----------|-----------------------------------|
| 31:0   | COMPARE5H | Higher word compare value of GPT5 |

## 15. Pulse Width Modulation

### 15.1. Overview

The generic pulse width modulators (PWM) are implemented to generate pulse sequences with programmable frequency and duty cycle for LCD backlight. The duration of the PWM output signal is HIGH as long as the internal counter value is between the threshold up and threshold down values. The waveform is shown in Figure 15.1-1.



Figure 15.1-1. PWM waveform

### 15.2. Features

Classic mode — the output waveform is specified by the internal counter (PWM\_1CH\_COUNT), threshold up value (PWM\_1CH\_THRESH\_UP), threshold down value (PWM\_1CH\_THRESH\_DOWN), clock source select (PWM\_1CH\_CLK\_CTRL[3:2]) and clock prescaler scale (PWM\_1CH\_CLK\_CTRL[1:0]).

### 15.3. Block diagram

The block diagram for the PWM is shown in Figure 15.3-1 .



**Figure 15.3-1. PWM block diagram**

## 15.4. Functions

- Classic mode

The frequency and volume of the PWM output signal are determined by registers PWM\_1CH\_CLK\_CTRL, PWM\_1CH\_THRESH\_UP, PWM\_1CH\_THRESH\_DOWN and PWM\_1CH\_COUNT. The power down signal (pwm\_1ch\_pdn) is applied to power down the PWM\_1CH module. When PWM\_1CH is deactivated (pwm\_1ch\_pdn = 1), the output will be in LOW state.

The output PWM frequency is determined by:

$$\frac{CLK}{CLOCK\_DIV \times (PWM\_1CH\_COUNT + 1)}$$

CLK = 13 MHz, when PWM\_1CH\_CLK\_CTRL[3:2] = 2'b00

CLK = 32 KHz, when PWM\_1CH\_CLK\_CTRL[3:2] = 2'b01

CLK = 40MHz, when PWM\_1CH\_CLK\_CTRL[3:2] = 2'b10

CLOCK\_DIV = 1, when PWM\_1CH\_CLK\_CTRL[1:0] = 2'b00

CLOCK\_DIV = 2, when PWM\_1CH\_CLK\_CTRL[1:0] = 2'b01

CLOCK\_DIV = 4, when PWM\_1CH\_CLK\_CTRL[1:0] = 2'b10

CLOCK\_DIV = 8, when PWM\_1CH\_CLK\_CTRL[1:0] = 2'b11

The output PWM duty cycle is determined by:

$$\frac{PWM\_1CH\_THRESH\_UP - PWM\_1CH\_THRESH\_DOWN + 1}{PWM\_1CH\_COUNT + 1}$$

Note that PWM\_1CH\_THRESH\_UP should be less than PWM\_1CH\_COUNT, and PWM\_1CH\_THRESH\_DOWN should be less than PWM\_1CH\_THRESH\_UP. If this condition is not satisfied, the output pulse of the PWM will be always high or always low. Figure 15.4-1 is the PWM waveform with indicated register values.



Figure 15.4-1. PWM waveform with register values

## 15.5. Register mapping

There are six PWM channels in this SOC. The channels and their base addresses are shown in the table below.

| PWM number | Base address |
|------------|--------------|
| PWM0       | 0xA2120000   |
| PWM1       | 0xA2130000   |
| PWM2       | 0xA2140000   |
| PWM3       | 0xA2150000   |
| PWM4       | 0xA2160000   |
| PWM5       | 0xA2170000   |

**Module name: PWMO Base address: (+a2120000h)**

| Address  | Name                            | Width (bits) | Register functionality                    |
|----------|---------------------------------|--------------|-------------------------------------------|
| A2120000 | <u>PWM_1CH_CTRL_ADDR</u>        | 16           | <b>PWM control register</b>               |
| A2120004 | <u>PWM_1CH_COUNT_ADDR</u>       | 16           | <b>PWM maximum counter value register</b> |
| A2120008 | <u>PWM_1CH_THRESH_UP_ADDR</u>   | 16           | <b>PWM threshold_up value register</b>    |
| A212000C | <u>PWM_1CH_THRESH_DOWN_ADDR</u> | 16           | <b>PWM threshold_down value register</b>  |

| A2120000 PWM_1CH_CTRL_ADDR PWM control register 00000000 |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |    |
|----------------------------------------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|----|
| Bit Name                                                 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0  |
| Type                                                     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW |

|               |   |   |   |   |
|---------------|---|---|---|---|
| <b>Res et</b> | 0 | 0 | 0 | 0 |
|---------------|---|---|---|---|

| <b>Bit(s)</b> | <b>Name</b>      | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0           | PWM_1CH_CLK_CTRL | <p><b>Bit [1:0] : Selects clock prescaler scale of PWM</b></p> <p>[1:0] = 2'boo : f = fclk<br/> [1:0] = 2'b01 : f = fclk/2<br/> [1:0] = 2'b10 : f = fclk/4<br/> [1:0] = 2'b11 : f = fclk/8</p> <p><b>Bit [3:2] : Selects source clock frequency of PWM</b></p> <p>[3:2] = 2'boo : CLK = 13MHz<br/> [3:2] = 2'b01 : CLK = 32kHz (able to work in sleep mode)<br/> [3:2] = 2'b10 : CLK = 40MHz<br/> [3:2] = 2'b11 : CLK = 40MHz</p> |

**A2120004 PWM\_1CH\_COUNT\_A PWM max counter value register DDR** 0oooooooooooo

| <b>Bit Na me</b> | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Type</b>      | RW |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Res et</b>    | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

| <b>Bit(s)</b> | <b>Name</b>   | <b>Description</b>                                                                                                                                                                                                                                                                                                                                  |
|---------------|---------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12:0          | PWM_1CH_COUNT | <p><b>PWM maximum counter value</b></p> <p>This is the initial value for the internal counter. Regardless of the operation mode, if PWM_1CH_COUNT is written when the internal counter is counting backwards, the new initial value will not take effect until the internal counter counts down to 0, consider a complete period as an example.</p> |

**A212000 8 PWM\_1CH\_THRESH\_UP PWM threshold\_up value register ADDR** 0oooooooooooo

| <b>Bit Na me</b> | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>Type</b>      | RW |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| <b>Res et</b>    | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |   |

| <b>Bit(s)</b> | <b>Name</b>       | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                   |
|---------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12:0          | PWM_1CH_THRESH_UP | <p><b>PWM threshold-up value</b></p> <ul style="list-style-type: none"> <li>When the internal counter value is greater than or equal to PWM_1CH_THRESH_UP and less than PWM_1CH_THRESH_DOWN, the PWM output signal will be "1".</li> <li>When the internal counter value is less than PWM_1CH_THRESH_UP or bigger than PWM_1CH_THRESH_DOWN, the PWM output signal will be</li> </ul> |

---

"0".

---

**A212000 PWM\_1CH\_THRESH\_D PWM threshold\_down value register 0oooooooooooo**  
**C OWN\_ADDR**

| Bit                               | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-----------------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| <b>PWM_1CH_THRESH_DOWN</b>        |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| RW                                |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit(s) | Name                | Description                                                                                                                                                                                                                                                                                                                                                                                 |
|--------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12:0   | PWM_1CH_THRESH_DOWN | <p><b>PWM threshold-down value</b></p> <ul style="list-style-type: none"> <li>When the internal counter value is greater than or equal to PWM_1CH_THRESH_UP and less than PWM_1CH_THRESH_DOWN, the PWM output signal will be "1".</li> <li>When the internal counter value is less than PWM_1CH_THRESH_UP or bigger than PWM_1CH_THRESH_DOWN, the PWM output signal will be "0".</li> </ul> |

## 16. Cortex-M4 L1 Cache Controller

### 16.1. Overview

Mediatek MT7682 core processor is implemented with a subsystem including the core cache and tightly coupled memory (TCM). The subsystem is placed between the MCU core and AHB bus interface, as shown in Figure 16.1-1 .



**Figure 16.1-1. MCU, Cache, TCM and AHB bus connectivity**

TCM is a high-speed (zero wait state) dedicated memory accessed exclusively by the MCU. Due to the latency penalty when the MCU accesses memory or peripherals through the on-chip bus, moving timing critical code and data into TCM can enhance the performance of the MCU and guarantee the response to particular events.

Another method to enhance MCU performance is the implementation of cache. In this case, the core cache is a small block of memory containing a copy of a small portion of cacheable data in the external memory. If the MCU reads a cacheable datum, the datum will be copied into the core cache. Once the MCU requests the same datum again, it can be obtained directly from the core cache (called cache hit) instead of fetching it again from the external memory. Consider the fact that accessing cache is much faster than accessing external memory through the bus system, a faster instruction fetching can be obtained leading to a higher instructions per cycle (IPC) which is a major factor in the evaluation of core performance. Since a large external memory maps to a small cache, the cache can hold only a small portion of external memory. If MCU accesses a datum not found in the cache (called cache miss), one cache line must be dropped (flushed), and the required datum and its neighboring data are transferred from the external memory to cache (cache line fill). Before the cache line fill, “cache write back” to maintain data consistency between cache and external memory needs to be performed. In this design, a cache line consists of eight words (8x32 bits). On the other hand, the best way to utilize TCM is to maintain the critical instruction or data in TCM. After system reset, the bootloader copies TCM content from the external storage, such as flash, to the internal TCM. If necessary, the MCU can replace TCM content with other data in the external storage during the runtime to implement a mechanism such as “overlay”. TCM is also ideal to store stack data.

The sizes of TCM and cache can be set to one of the following four configurations:

- 64KB TCM, 32KB cache
- 80KB TCM, 16KB cache
- 88KB TCM, 8KB cache
- 96KB TCM, 0KB cache (no cache)

**Figure 16.1-2. Cache size and TCM settings**

These different configurations provide flexibility for software to adjust and reach optimum system performance.

The address mapping of these memories is shown in Table 16.1-1 .

**Table 16.1-1. TCM address spaces for different cache size settings**

| Cache Size                             | SYSRAM Identity | Used as                           |
|----------------------------------------|-----------------|-----------------------------------|
| 2'b00<br>(Total TCM = 96KB, cache = 0) | SYSRAM_2K_0     | TCM0 (0x0400_0000 to 0x0400_07FF) |
|                                        | SYSRAM_2K_1     | TCM1 (0x0400_0800 to 0x0400_0FFF) |
|                                        | SYSRAM_2K_2     | TCM2 (0x0400_1000 to 0x0400_17FF) |
|                                        | SYSRAM_2K_3     | TCM3 (0x0400_1800 to 0x0400_1FFF) |
|                                        | SYSRAM_4K_0     | TCM4 (0x0400_2000 to 0x0400_2FFF) |
|                                        | SYSRAM_4K_1     | TCM5 (0x0400_3000 to 0x0400_3FFF) |
|                                        | SYSRAM_8K_0     | TCM6 (0x0400_4000 to 0x0400_5FFF) |

| Cache Size                                | SYSRAM Identity | Used as                                    |
|-------------------------------------------|-----------------|--------------------------------------------|
|                                           | SYSRAM_8K_1     | TCM7 (0x0400_6000 to 0x0400_7FFF)          |
|                                           | SYSRAM_16K_0~4  | TCM8 (0x0400_8000 to 0x0401_7FFF)          |
| 2'b01<br>(Total TCM = 88KB, cache = 8KB)  | SYSRAM_2K_0     | Cache way 0                                |
|                                           | SYSRAM_2K_1     | Cache way 1                                |
|                                           | SYSRAM_2K_2     | Cache way 2 or way 0 (2-way configuration) |
|                                           | SYSRAM_2K_3     | Cache way 3 or way 1 (2-way configuration) |
|                                           | SYSRAM_4K_0     | TCM4 (0x0400_2000 to 0x0400_2FFF)          |
|                                           | SYSRAM_4K_1     | TCM5 (0x0400_3000 to 0x0400_3FFF)          |
|                                           | SYSRAM_8K_0     | TCM6 (0x0400_4000 to 0x0400_5FFF)          |
|                                           | SYSRAM_8K_1     | TCM7 (0x0400_6000 to 0x0400_7FFF)          |
|                                           | SYSRAM_16K_0~4  | TCM8 (0x0400_8000 to 0x0401_7FFF)          |
| 2'b10<br>(Total TCM = 80KB, cache = 16KB) | SYSRAM_2K_0     | Cache way 0                                |
|                                           | SYSRAM_2K_1     | Cache way 0                                |
|                                           | SYSRAM_2K_2     | Cache way 1                                |
|                                           | SYSRAM_2K_3     | Cache way 1                                |
|                                           | SYSRAM_4K_0     | Cache way 2 or way 0 (2-way configuration) |
|                                           | SYSRAM_4K_1     | Cache way 3 or way 1 (2-way configuration) |
|                                           | SYSRAM_8K_0     | TCM6 (0x0400_4000 to 0x0400_5FFF)          |
|                                           | SYSRAM_8K_1     | TCM7 (0x0400_6000 to 0x0400_7FFF)          |
|                                           | SYSRAM_16K_0~4  | TCM8 (0x0400_8000 to 0x0401_7FFF)          |
| 2'b11<br>(Total TCM = 64KB, cache = 32KB) | SYSRAM_2K_0     | Cache way 0                                |
|                                           | SYSRAM_2K_1     | Cache way 0                                |
|                                           | SYSRAM_2K_2     | Cache way 0                                |
|                                           | SYSRAM_2K_3     | Cache way 0                                |
|                                           | SYSRAM_4K_0     | Cache way 1                                |
|                                           | SYSRAM_4K_1     | Cache way 1                                |
|                                           | SYSRAM_8K_0     | Cache way 2 or way 0 (2-way configuration) |
|                                           | SYSRAM_8K_1     | Cache way 3 or way 1 (2-way configuration) |
|                                           | SYSRAM_16K_0~4  | TCM8 (0x0400_8000 to 0x0401_7FFF)          |

## 16.2. Cache optimization

The cache system has the following features:

- 1) Write back (unit: 4 words)
- 2) Configurable two or four way set associative
  - a) 2-way set associative
    - i) 128/256/512-set for 8, 16 or 32KB cache size, respectively.
    - ii) Each way has 128, 256 or 512 cache lines with 8-word line size.
  - b) 4-way set associative

- i) 64/128/256-set for 8, 16 or 32KB cache size, respectively.
- ii) Each way has 64, 128 or 256 cache lines with 8-word line size
- 3) 20-bit tag memory: 19-bit high address and 1-bit valid bit.
- 4) 2-bit dirty memory (each dirty bit records the dirtiness of half cache line – 4 words).



**Figure 16.2-1. Cache lookup for 4-way set associative**

Each set associative cache has two memories: tag memory and data memory. The tag memory stores each line's valid bit and tag (upper 19 bits of the address). The data memory stores line data. When MCU accesses the memory, the address is compared to the content of the tag memory. First, the line index (address bits [12:5]) is used to locate a line in the tag memory. When a particular line is found in the tag memory, the upper 19 bits (address bits [31:13]), called tag, of the desired memory address are compared with the content of the found tag line. If a match is found in both line address and tag address and the valid bit is 1, it is called a cache hit, and the data from that particular cache way is returned to the MCU. This process is shown in Figure 16.2-1.

If most memory accesses are cache hit, the MCU is able to acquire data without any delay, and the overall system performance will be higher. There are several factors that may affect the cache hit rate:

- Cache size and the organization

The larger the cache size, the higher the hit rate. However, the hit rate saturates when the cache size is larger than a threshold size. Normally the size of 16KB and above and two or four way set associative cache configuration can achieve a higher hit rate.

- 2 or 4-way set associative
  - 4-way set associative has higher hit rate than 2-way. However, the power consumption will be higher as it accesses more memory during cache lookup.
- Program behavior

If the system has several tasks and switches between the tasks frequently, it may result in frequent cache content flush, as each time a new task is running, the cache holds its data for a certain period of time assuming it'll be used again. However, the stored data might get flushed out before being used again, if the following task requires the data occupying the same cache entries. Interrupts can cause program flow to change dynamically and reduce the benefit of using cache. The interrupt handler and the data it processes may cause cache to flush out data used by the current task. Thus, after returning from the interrupt handler to current task, the flushed data may need to be filled into the cache again if it's required by the program routine. This will cause performance degradation.

To tune the system performance, the cache controller in MT7682 records the cache hit count and number of cacheable memory accesses. The cache hit rate can be obtained by dividing these two numbers.

### 16.2.1. Write-back or write-through configurable cache

There are two different types of cache design to maintain data consistency. One is cache write-through, and the other is cache write-back.

The write-back cache improves the performance especially when processors generate writes as fast as or faster than the writes that can be handled by the external memory. However, the implementation of write-back is more complex than that of write-through. When a cache line is dirty, four or eight words will be written back to the external memory at once, and this will certainly occupy significant bus bandwidth and therefore decrease the overall efficiency. To solve this problem, a write buffer is necessary in the write-back implementation. Once the writes are written into the write buffer, the processor can continue the execution.

For systems with large memory write latency, it's possible that the burst write of cache write-back operation may cause large impact on the system performance, change the cache to write-through mode in the software, if necessary.

#### 16.2.1.1. Write-back implementation

When a cache hit occurs at write request, only the cache content will be modified, and the dirty bit will be set. The modified cache content won't match with that in the external memory, unlike cache write-through, which modifies both the cache content and the external memory synchronously.

When the cache misses the read request, line fill will be performed and a randomly selected cache line will be replaced, but before that, the dirty bits of that selected cache line have to be checked for the necessity of write-back. If the dirty bits are not set, line fill can proceed right away, and the selected cache line can be simply abandoned and replaced by a newly fetched line from the external memory which consists of the requested data. On the other hand, if one or both the dirty bits are set, write-back has to be performed before line fill. In that case, half or the entire cache line is written into the write buffer. A summary is given in Figure 16.2-2:



**Figure 16.2-2. Cache miss/refill criteria**

#### 16.2.1.2. Write buffer

The write buffer consists of address buffer, data buffer, buffer for HTRANS, buffer for HSIZE, buffer for HLOCK and buffer for HBURST. The write buffer is designed as first-in-first-out (FIFO) with a depth eight words. Since the outputs from the code cache meet the AMBA format, the address buffer and data buffer are independent. The outputs of write buffer suffice the AMBA formatting guidelines and are designed for pipelining.

All CPU write accesses through the I/D bus will be buffered, no matter it's within the cacheable region or not.

#### 16.2.2. Cache operation

Upon power-on, the cache memory contains random values. The MCU needs to invalidate the cache content before enabling the cache usage.

The MCU needs to flush the cache data to the external memory to maintain data coherency before disabling the cache controller or MCU power-off.

The cache controller provides a register which, when written, can operate on the cache memory to fulfill the prerequisite mentioned above (called cache operation).

The operation involves:

- 1) Invalidate one cache line

The user must give a memory address. If it's found within the cache, that particular cache line will be invalidated by writing 0 in the valid bit at the corresponding tag line. Alternatively, the user can invalidate a cache line by specifying a set/way mapped to that cache line.

- 2) Invalidate all cache lines

The user doesn't need to specify an address. The cache controller clears valid bits in all tag lines when this operation is requested.

- 3) Flush one cache line

The user must give a memory address. If it's found within the cache and the dirty bit or bits are set, that particular cache line containing the given address will be flushed into the write buffer. Alternatively, the user can flush a cache line by specifying a set/way mapped to that cache line. This operation is not supported if the cache is operating in the write-through mode.

#### 4) Flush all cache lines

The user doesn't need to specify an address. The cache controller flushes all the cache lines with the dirty bit or bits set. This operation is not supported if the cache is operating in the write-through mode.

**Note:** To configure the cache size, follow the steps below to prevent cache data loss during the cache size configuration. At initialization, the cache size is set to 0.

- 1) Flush all cache lines.
- 2) Invalidate all cache lines.
- 3) Configure the TCM and cache size.

### 16.2.3. Summary of cache operation

*Table 16.2-1. Write-back mode cache read or write operations*

| Op    | Cacheable | Hit | Dirty |       | Action                                                                                                                                                                                                         |
|-------|-----------|-----|-------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       |           |     | W0~W3 | W4~W7 |                                                                                                                                                                                                                |
| Read  | N         | d   | d     | d     | Single read                                                                                                                                                                                                    |
|       | Y         | Y   | d     | d     | Return data, no stall                                                                                                                                                                                          |
|       |           | N   | N     | N     | Line refill from bus using AHB WRAP8 burst                                                                                                                                                                     |
|       |           |     | N     | Y     | <ul style="list-style-type: none"> <li>• Evict half line to WBuf.</li> <li>• Line refill from bus using AHB WRAP8 burst.</li> <li>• Write back half line from WBbuf using AHB INCR4 burst write.</li> </ul>    |
|       |           |     | Y     | N     | <ul style="list-style-type: none"> <li>• Evict whole line to WBbuf.</li> <li>• Line refill from bus using AHB WRAP8 burst.</li> <li>• Write back whole line from WBbuf using AHB INCR8 burst write.</li> </ul> |
|       |           | Y   | Y     |       | <ul style="list-style-type: none"> <li>• Evict whole line to WBbuf.</li> <li>• Line refill from bus using AHB WRAP8 burst.</li> <li>• Write back whole line from WBbuf using AHB INCR8 burst write.</li> </ul> |
| Write | N         | d   | d     | d     | <ul style="list-style-type: none"> <li>• Wait for WBbuf space.</li> <li>• Place write data into WBbuf and let the MCU continue operating (CLKEN = 1). Stall the MCU by one cycle.</li> </ul>                   |
|       | Y         | Y   | d     | d     | <ul style="list-style-type: none"> <li>• Write into cache; meanwhile set up the corresponding dirty bit.</li> <li>• Stall the MCU by one cycle to avoid structural hazard.</li> </ul>                          |
|       |           | N   | d     | d     | <ul style="list-style-type: none"> <li>• Wait for WBbuf space.</li> <li>• Place write data into WBbuf and let the MCU continue operating (CLKEN = 1). Stall the MCU by one cycle.</li> </ul>                   |

Legend Y: yes, N: no, d: don't care

Table 16.2-2. Write-through mode cache R/W action summary

| Op    | Cacheable | Hit | Action                                                                                                                                                                                                                |
|-------|-----------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Read  | N         | d   | Single read                                                                                                                                                                                                           |
|       | Y         | Y   | <ul style="list-style-type: none"> <li>Return data, no stall</li> </ul>                                                                                                                                               |
|       |           | N   | <ul style="list-style-type: none"> <li>Line read from bus using AHB WRAP8 burst</li> </ul>                                                                                                                            |
| Write | N         | d   | <ul style="list-style-type: none"> <li>Wait for WBuf space.</li> </ul>                                                                                                                                                |
|       | Y         | N   | <ul style="list-style-type: none"> <li>Place write data into WBuf and let the MCU continue operating (CLKEN = 1). Stall Cortex-M4 by one cycle.</li> </ul>                                                            |
|       |           | Y   | <ul style="list-style-type: none"> <li>Write to data SRAM.</li> <li>Wait for WBuf space.</li> <li>Place write data into WBuf and let the MCU continue operating (CLKEN = 1). Stall Cortex-M4 by one cycle.</li> </ul> |

Legend Y: yes, N: no, d: don't care

### 16.3. Register mapping

**Module name: CACHE Base address: (+E018000oh)**

| CACHE+ooh Cache general control register |    |    |    |    |    |               |                  |   |   |   |   |   |                |                | CACHE_CON |              |  |  |
|------------------------------------------|----|----|----|----|----|---------------|------------------|---|---|---|---|---|----------------|----------------|-----------|--------------|--|--|
| Bit                                      | 15 | 14 | 13 | 12 | 11 | 10            | 9                | 8 | 7 | 6 | 5 | 4 | 3              | 2              | 1         | 0            |  |  |
| <b>Name</b>                              |    |    |    |    |    | <b>2WAYEN</b> | <b>CACHESIZE</b> |   |   |   |   |   | <b>CNTE_N1</b> | <b>CNTE_No</b> |           | <b>MCE_N</b> |  |  |
| <b>Type</b>                              |    |    |    |    |    | RW            | RW               |   |   |   |   |   | RW             | RW             |           | R/W          |  |  |
| <b>Reset</b>                             |    |    |    |    |    | 0             | 00               |   |   |   |   |   | 0              | 0              |           | 0            |  |  |

This register determines the size of cache, cache hit counter and the enabling of MPU.

**2WAYEN** Enable 2-way cache look-up

- 0** Disable (4-way)
- 1** Enable (2-way)

**CACHESIZE** Selects cache size

- 00** No cache
- 01** 8KB
- 10** 16KB
- 11** 32KB

**CNTEN1** Enables cache hit counter 1

If enabled, the cache controller will increment a 48-bit counter by one when a cache hit is detected. This number is used in performance evaluation of the application. This counter increments only when the data are obtained from MPU cacheable regions 8 to 15.

- 0** Disable
- 1** Enable

**CNTENO** Enables cache hit counter 0

If enabled, the cache controller will increment a 48-bit counter by one when a cache hit is detected. This number is used in performance of the application. This counter increments only when the data are obtained from MPU cacheable regions 0 to 7.

- 0** Disable
- 1** Enable

**MCEEN** Enables the comparison of cacheable/non-cacheable setting

If disabled, the MCU memory accesses are all non-cacheable, i.e. they will go through the AHB bus (except for TCM access). When enabled, if MCU accesses a cacheable memory region, the cache controller will return the data if it is found in cache and will get the data through the AHB bus only if a cache miss occurs.

- 0** Disable
- 1** Enable

**CACHE+04h Cache operation****CACHE\_OP**

| Bit   | 31                  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21             | 20 | 19 | 18 | 17        | 16 |
|-------|---------------------|----|----|----|----|----|----|----|----|----|----------------|----|----|----|-----------|----|
| Name  | <b>TADDR[31:16]</b> |    |    |    |    |    |    |    |    |    |                |    |    |    |           |    |
| Type  | R/W                 |    |    |    |    |    |    |    |    |    |                |    |    |    |           |    |
| Reset | 0                   |    |    |    |    |    |    |    |    |    |                |    |    |    |           |    |
| Bit   | 15                  | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5              | 4  | 3  | 2  | 1         | 0  |
| Name  | <b>TADDR[15:5]</b>  |    |    |    |    |    |    |    |    |    | <b>OP[3:0]</b> |    |    |    | <b>EN</b> |    |
| Type  | R/W                 |    |    |    |    |    |    |    |    |    | W              |    |    |    | W1        |    |
| Reset | 0                   |    |    |    |    |    |    |    |    |    | 0              |    |    |    | 0         |    |

This register defines the address and/or which type of cache operation to apply. When MCU writes into this register, the pipeline of MCU will be stopped for the cache controller to complete the operation. Bit 0 of the register must be written as 1 to enable the command.

**TADDR[31:5]** Target address

This field contains the address of invalidation operation. If OP[3:0] = 0010, TADDR[31:5] will be the address[31:5] of a memory whose line will be invalidated if it exists in the cache. If OP[3:0] = 0100, TADDR[12:5] will indicate the set, while TADDR[19:16] indicates which way to clear:

- 0001** way #0 (4-way)/way #0 first half (2-way)
- 0010** way #1 (4-way)/way #1 first half (2-way)
- 0100** way #2 (4-way)/way #0 second half (2-way)
- 1000** way #3 (4-way)/way #1 second half (2-way)

\* For 2-way cache configuration, this operation has to be done twice in order to clear the entire way.

**OP[3:0]** Operation

This field determines which cache operations will be performed.

- 0001** invalidate all cache lines
- 0010** invalidate one cache line using address

- 0100** invalidate one cache line using set/way
- 1001** flush all cache lines
- 1010** flush one cache line using address
- 1100** flush one cache line using set/way

**EN** Enables command  
 This enabling bit must be written 1 to enable the command.  
**0** Does not enable  
**1** Enable

#### CACHE+08h Cache hit count o lower part CACHE\_HCNToL

| Bit   | 31                      | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|-------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | <b>CHIT_CNTo[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15                      | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>CHIT_CNTo[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

#### CACHE+0Ch Cache hit count o upper part CACHE\_HCNToU

| Bit   | 31                      | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|-------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | <b>RESERVED</b>         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15                      | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>CHIT_CNTo[47:32]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

When the CNTENO bit in the CACHE\_CON register is set to 1 (enabled), this register will start to record the cache hit count until it is disabled. If the value increases to above the maximum value (0xffffffffffff), it will be rolled over to 0 and continue counting. The 48-bit counter provides a recording time of 31 days even if MCU runs at 104MHz, and every cycle is a cache hit. Note, that before enabling the counter, writing the initial value 0 to the counter is recommended.

#### CHIT\_CNTo[47:0] Cache hit count o

**WRITE** Write any value to CACHE\_HCNToL or CACHE\_HCNToU clears

CHIT\_CNTo to all 0.

**READ** Current counter value

#### CACHE+10h Cacheable access count o lower part CACHE\_CCNToL

| Bit   | 31                      | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|-------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | <b>CACC_CNTo[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15                      | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |

|       |                        |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-------|------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Name  | <b>CACC_CNTo[15:0]</b> |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Type  | R/W                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| Reset | 0                      |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| <b>CACHE+14h Cacheable access count o upper part</b> |                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>CACHE_CCNToU</b> |
|------------------------------------------------------|-------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------|
| Bit                                                  | 31                      | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |                     |
| Name                                                 | <b>RESERVED</b>         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                     |
| Type                                                 |                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                     |
| Reset                                                |                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                     |
| Bit                                                  | 15                      | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |                     |
| Name                                                 | <b>CACC_CNTo[47:32]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                     |
| Type                                                 | R/W                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                     |
| Reset                                                | 0                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                     |

When the CNTENO bit in the CACHE\_CON register is set to 1 (enabled), this register is incremented at each cacheable memory access (no matter whether it is a cache miss or a cache hit). If the value increases to above the maximum value (0xffffffffffff), it will be rolled over to 0 and continue counting. For 104MHz MCU speed, if all memory accesses are cacheable and cache hit, this counter will overflow after  $(2^{48}) * 9.6\text{ns} = 31$  days. This is the shortest time for the counter to overflow. In a more realistic case, the system will have cache misses, non-cacheable accesses and idle mode that makes the counter overflow at later time.

#### **CACC\_CNTo[47:0] Cache access count o**

**WRITE** Write any value to CACHE\_CCNToL or CACHE\_CCNToU clears CACC\_CNTo to all 0.

**READ** Current counter value

The best way to use CACHE\_HCNTo and CACHE\_CCNTo is to set the initial value to 0 for both registers, enable both counters (set CNTENO to 1), run a portion of program to be benchmarked, stop the counters and get their values. Therefore, during this period,

$$\text{Cache hit rate} = \frac{\text{CACHE\_HCNT}}{\text{CACHE\_CCNT}} \times 100\%$$

The cache hit rate value may help tune the performance of the application program. Note that CHIT\_CNT1 and CACC\_CNT1 only increment if the cacheable attribute is defined in MPU cacheable region lower half channels (i.e. channels 0 ~ 7 of the total 16 channels).

| <b>CACHE+18h Cache hit count 1 lower part</b> |                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>CACHE_HCNT1L</b> |
|-----------------------------------------------|-------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------|
| Bit                                           | 31                      | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |                     |
| Name                                          | <b>CHIT_CNT1[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                     |
| Type                                          | R/W                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                     |
| Reset                                         | 0                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                     |
| Bit                                           | 15                      | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |                     |
| Name                                          | <b>CHIT_CNT1[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                     |
| Type                                          | R/W                     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                     |
| Reset                                         | 0                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                     |

**CACHE+1Ch Cache hit count 1 upper part****CACHE\_HCNT1U**

|       |                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31               | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  | RESERVED         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15               | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | CHIT_CNT1[47:32] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

When the CNTEN1 bit in CACHE\_CON register is set to 1 (enabled), this register will start to record the cache hit count until it is disabled. If the value increases to above the maximum value (0xffffffffffff), it will be rolled over to 0 and continue counting. The 48-bit counter provides a recording time of 31 days even if MCU runs at 104MHz, and every cycle is a cache hit. Note, that before enabling the counter, writing the initial value 0 to the counter is recommended.

**CHIT\_CNT1[47:0] Cache hit count**

**WRITE** Write any value to CACHE\_HCNT1L or CACHE\_HCNT1U clears

CHIT\_CNT1 to all 0.

**READ** Current counter value

**CACHE+20h Cacheable access count 1 lower part****CACHE\_CCNT1L**

|       |                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31               | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  | CACC_CNT1[31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15               | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | CACC_CNT1[15:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**CACHE+24h Cacheable access count 1 upper part****CACHE\_CCNT1U**

|       |                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31               | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  | RESERVED         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15               | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | CACC_CNT1[47:32] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R/W              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

When CNTEN1 bit in CACHE\_CON register is set to 1 (enabled), this register is incremented at each cacheable memory access (no matter whether it is a cache miss or a cache hit). If the value increases to above the maximum value (0xffffffffffff), it will be rolled over to 0 and continue counting. For 104MHz MCU speed, if all memory accesses are cacheable and cache hit, this counter will overflow after  $(2^{48}) * 9.6\text{ns} = 31$  days. This is the shortest time for the counter to overflow. In a more realistic case, the system will have cache misses, non-cacheable accesses and idle mode that makes the counter overflow at later time.

**CACC\_CNT1[47:0]** Cache access count 1

**WRITE** Write any value to CACHE\_CCNT1L or CACHE\_CCNT1U clears

CACC\_CNT1 to all 0.

**READ** Current counter value

The best way to use CACHE\_HCNT1 and CACHE\_CCNT1 is to set the initial value to 0 for both registers, enable both counters (set CNTEN1 to 1), run a portion of program to be benchmarked, stop the counters and get their values. Therefore, during this period,

$$\text{Cache hit rate} = \frac{\text{CACHE\_HCNT}}{\text{CACHE\_CCNT}} \times 100\%.$$

The cache hit rate value may help tune the performance of the application program. Note that CHIT\_CNT1 and CACC\_CNT1 only increment if the cacheable attribute is defined in MPU cacheable region for upper half channels (i.e. channels 8 ~ 15 of the total 16 channels).

|       | CACHE+2C Cache region enable |             |             |             |             |             |            |            |            |            |            |            |            |            |            | CACHE_REGION_EN |  |
|-------|------------------------------|-------------|-------------|-------------|-------------|-------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|-----------------|--|
| Bit   | 31                           | 30          | 29          | 28          | 27          | 26          | 25         | 24         | 23         | 22         | 21         | 20         | 19         | 18         | 17         | 16              |  |
| Name  |                              |             |             |             |             |             |            |            |            |            |            |            |            |            |            |                 |  |
| Type  |                              |             |             |             |             |             |            |            |            |            |            |            |            |            |            |                 |  |
| Reset |                              |             |             |             |             |             |            |            |            |            |            |            |            |            |            |                 |  |
| Bit   | 15                           | 14          | 13          | 12          | 11          | 10          | 9          | 8          | 7          | 6          | 5          | 4          | 3          | 2          | 1          | 0               |  |
| Name  | <b>CH15</b>                  | <b>CH14</b> | <b>CH13</b> | <b>CH12</b> | <b>CH11</b> | <b>CH10</b> | <b>CH9</b> | <b>CH8</b> | <b>CH7</b> | <b>CH6</b> | <b>CH5</b> | <b>CH4</b> | <b>CH3</b> | <b>CH2</b> | <b>CH1</b> | <b>CH0</b>      |  |
| Type  | R/W                          | R/W         | R/W         | R/W         | R/W         | R/W         | R/W        | R/W        | R/W        | R/W        | R/W        | R/W        | R/W        | R/W        | R/W        | R/W             |  |
| Reset | 0                            | 0           | 0           | 0           | 0           | 0           | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0          | 0               |  |

**CH15~CH0** Enables/Disables the associated region

- 0** Disable the region setting
- 1** Enable the region setting

## 16.4. Cacheable region controller

Cacheable region controller provides cacheable memory indication, featuring cacheable settings and attributes.

### 16.4.1. Cacheable settings

- Determine if a memory region is cacheable or not. If cacheable, MCU will keep a small copy in its cache after read accesses. If MCU requires the same data later, it can acquire it from the high-speed local copy, instead of low-speed external memory.
- The 4GB memory space is divided into 16 memory blocks with 256MB size each, i.e. MB0 to MB15. The characteristics of these memory blocks are listed below:
- All memory blocks are determined by the Cacheable Region Controller. Note, that the software should avoid making cache line access to the MB that does not support burst read/write. Usually only MB0 ~ MB1, mapped to EMI, are set as cacheable regions.

### 16.4.2. Cacheable attribute



**Figure 16.4-1. Cacheable setting example**

Figure 16.4-1 provides cacheable settings in each memory block. Five regions are defined in the figure. Note, that each region can be continuous or non-continuous to each other. The address ranges not covered by any region in

the cacheable settings are set to be uncacheable automatically. There is also one restriction: different regions must not overlap.

The user can define a maximum of 16 regions in MB0 ~ MB1. Each region has its own settings defined in a 32-bit register:

### Register format

|       |                        |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |  |
|-------|------------------------|----|----|----|----|----|----|----|-----|----|----|----|----|----|----|----|--|
| Bit   | 31                     | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22 | 21 | 20 | 19 | 18 | 17 | 16 |  |
| Name  | <b>BASEADDR[31:16]</b> |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |  |
| Type  | R W                    |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |  |
| Reset |                        |    |    |    |    |    |    |    |     |    |    |    |    |    |    |    |  |
| Bit   | 15                     | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7   | 6  | 5  | 4  | 3  | 2  | 1  | 0  |  |
| Name  | <b>BASEADDR[15:12]</b> |    |    |    |    |    |    |    | C   |    |    |    |    |    |    |    |  |
| Type  | R W                    |    |    |    |    |    |    |    | R W |    |    |    |    |    |    |    |  |
| Reset | 0                      |    |    |    |    |    |    |    | 0   |    |    |    |    |    |    |    |  |

#### 16.4.2.1. Region base address

The region base address defines the starting point of the memory region. The user must only specify several upper address bits and align the base address to a minimum 4KB boundary.

#### 16.4.2.2. Region size

The region size enumeration setting in the register is disabled in MT7682. Instead, use the CACHEABLE\_END register to specify the end address base of a certain channel. The end address is non-inclusive, and the BASEADDR is inclusive. For example, by setting BASEADDR to 0x1000 and END BASEADDR to 0x2000, any address in the range (0x1000, 0x2000) will match this cacheable region setting.

The CACHEABLE\_END register has 16 entries, starting right after the normal register and 0xE0190040 being the first entry.

*Table 16.4-1. Cacheable attribute bit encoding*

| Bit encoding | Permission    |
|--------------|---------------|
| 0            | Non-cacheable |
| 1            | Cacheable     |

### 16.4.3. Register mapping

**Module name: CACHE\_Entry Base address: (+E0190000h)**

| CACHE_EMTRY_base+4*(n-1) n-th channel control |                 |    |    |    |     |    |    |    |    |    |    |    |    |    |    | CACHE_entry_n |  |
|-----------------------------------------------|-----------------|----|----|----|-----|----|----|----|----|----|----|----|----|----|----|---------------|--|
| Bit                                           | 31              | 30 | 29 | 28 | 27  | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            |  |
| Name                                          | BASEADDR[31:16] |    |    |    |     |    |    |    |    |    |    |    |    |    |    |               |  |
| Type                                          | R W             |    |    |    |     |    |    |    |    |    |    |    |    |    |    |               |  |
| Reset                                         | 0               |    |    |    |     |    |    |    |    |    |    |    |    |    |    |               |  |
| Bit                                           | 15              | 14 | 13 | 12 | 11  | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0             |  |
| Name                                          | BASEADDR[15:12] |    |    |    | C   |    |    |    |    |    |    |    |    |    |    |               |  |
| Type                                          | R W             |    |    |    | R W |    |    |    |    |    |    |    |    |    |    |               |  |
| Reset                                         | 0               |    |    |    | 0   |    |    |    |    |    |    |    |    |    |    |               |  |

| CACHE_EMTRY_base+0x40 + 4*(n-1) n-th channel control |                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    | CACHE_End_entry_n |  |
|------------------------------------------------------|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-------------------|--|
| Bit                                                  | 31              | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                |  |
| Name                                                 | BASEADDR[31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |  |
| Type                                                 | R W             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |  |
| Reset                                                | 0               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |  |
| Bit                                                  | 15              | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                 |  |
| Name                                                 | BASEADDR[15:12] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |  |
| Type                                                 | R W             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |  |
| Reset                                                | 0               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                   |  |

- MT7682 supports 16 channels.
- Refer to register format for detailed field descriptions.

## 16.5. Remapping

MT7682 cache provides three sets of registers to create the actual memory address same as the different CPU load/store target address. Figure 16.5-1 shows the process of remapping.

The software sets 0x0xxxxxxx to cacheable and 0xFxxxxxxx to non-cacheable, but they are mapped to the same physical address.



Figure 16.5-1. Example settings of cache remapping

To achieve this:

1. Set regions beginning with 0x0000\_0000 to cacheable.
2. Set regions beginning with 0x1000\_0000 to non-cacheable.
3. Set BASEADDR field in Remap EntryHi to 0x1000\_0000.
4. Set BASEADDR filed in Remap EntryLo to 0x0000\_0000.

### 16.5.1. Register mapping

**Module name:** NC-Remap Base address: (+E0181000h)

**REMAP+0000h Remap Entry\_H10** **NCREMAP\_H10**

| Bit   | 31                     | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23               | 22 | 21 | 20 | 19        | 18 | 17 | 16 |
|-------|------------------------|----|----|----|----|----|----|----|------------------|----|----|----|-----------|----|----|----|
| Name  | <b>BASEADDR[31:16]</b> |    |    |    |    |    |    |    |                  |    |    |    |           |    |    |    |
| Type  | R W                    |    |    |    |    |    |    |    |                  |    |    |    |           |    |    |    |
| Reset |                        |    |    |    |    |    |    |    |                  |    |    |    |           |    |    |    |
| Bit   | 15                     | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7                | 6  | 5  | 4  | 3         | 2  | 1  | 0  |
| Name  | <b>BASEADDR[15:09]</b> |    |    |    |    |    |    |    | <b>SIZE[4:0]</b> |    |    |    | <b>EN</b> |    |    |    |
| Type  | R W                    |    |    |    |    |    |    |    | R W              |    |    |    | R W       |    |    |    |
| Reset |                        |    |    |    |    |    |    |    | 00000            |    |    |    | 0         |    |    |    |

This register sets up the remapping base attributes for region 0.

- BASEADDR** Base address of this region  
**SIZE** Size of this region (refer to Table 13)  
**EN** **ENABLES THIS REGION**  
**0** DISABLE  
**1** ENABLE

**REMAP+0004h Remap Entry\_LO0** **NCREMAP\_LO0**

| Bit   | 31                     | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|------------------------|----|----|----|----|----|----|----|-------|----|----|----|----|----|----|----|
| Name  | <b>BASEADDR[31:16]</b> |    |    |    |    |    |    |    |       |    |    |    |    |    |    |    |
| Type  | R W                    |    |    |    |    |    |    |    |       |    |    |    |    |    |    |    |
| Reset |                        |    |    |    |    |    |    |    |       |    |    |    |    |    |    |    |
| Bit   | 15                     | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7     | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>BASEADDR[15:09]</b> |    |    |    |    |    |    |    |       |    |    |    |    |    |    |    |
| Type  | R W                    |    |    |    |    |    |    |    |       |    |    |    |    |    |    |    |
| Reset |                        |    |    |    |    |    |    |    | 00000 |    |    |    | 0  |    |    |    |

This register sets up the mapped address base for CPU accesses that are hits in NC-Remap Entryo\_HI.

**REMAP+0008h Remap Entry\_HI1** **NCREMAP\_HI1**

| Bit   | 31                     | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23               | 22 | 21 | 20 | 19        | 18 | 17 | 16 |
|-------|------------------------|----|----|----|----|----|----|----|------------------|----|----|----|-----------|----|----|----|
| Name  | <b>BASEADDR[31:16]</b> |    |    |    |    |    |    |    |                  |    |    |    |           |    |    |    |
| Type  | R W                    |    |    |    |    |    |    |    |                  |    |    |    |           |    |    |    |
| Reset |                        |    |    |    |    |    |    |    |                  |    |    |    |           |    |    |    |
| Bit   | 15                     | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7                | 6  | 5  | 4  | 3         | 2  | 1  | 0  |
| Name  | <b>BASEADDR[15:09]</b> |    |    |    |    |    |    |    | <b>SIZE[4:0]</b> |    |    |    | <b>EN</b> |    |    |    |
| Type  | R W                    |    |    |    |    |    |    |    | R W              |    |    |    | R W       |    |    |    |
| Reset |                        |    |    |    |    |    |    |    | 00000            |    |    |    | 0         |    |    |    |

This register sets up the remapping base attributes for region 1.

**REMAP+000Ch Remap Entry\_LO1** **NCREMAP\_LO1**

| Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|

|       |                        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------|------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | <b>BASEADDR[31:16]</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | R W                    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset |                        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Bit   | 15                     | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name  | <b>BASEADDR[15:09]</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | R W                    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset |                        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

This register sets up the mapped address base for CPU accesses that are hits in NC-Remap Entry1\_HI.

### REMAP+0010h Remap Entry\_HI2

### NCREMAP\_HI2

|       |                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31                     | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  | <b>BASEADDR[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R W                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15                     | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>BASEADDR[15:09]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R W                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

This register sets up the remapping base attributes for region 2.

**BASEADDR** Base address of this region

**SIZE** Size of this region (refer to Table 13)

**EN** **ENABLES THIS REGION**

**0 DISABLE**

**1 ENABLE**

### REMAP+0014h Remap Entry\_LO2

### NCREMAP\_LO2

|       |                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|-------|------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit   | 31                     | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name  | <b>BASEADDR[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R W                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15                     | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | <b>BASEADDR[15:09]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | R W                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

This register sets up the mapped address base for CPU accesses that are hits in NC-Remap Entry2\_HI.

Note that the base and size settings in 3 EntryHi cannot be overlapped. Otherwise, the resultant mapped address will be undefined.

**Table 16.5-1. Region size and bit encoding**

| Region size | Bit encoding | Base address                        |
|-------------|--------------|-------------------------------------|
| 512B        | 00000        | Bit [31:09] of region start address |
| 1KB         | 00001        | Bit [31:10] of region start address |
| 2KB         | 00010        | Bit [31:11] of region start address |

| Region size | Bit encoding | Base address                        |
|-------------|--------------|-------------------------------------|
| 4KB         | 00011        | Bit [31:12] of region start address |
| 8KB         | 00100        | Bit [31:13] of region start address |
| 16KB        | 00101        | Bit [31:14] of region start address |
| 32KB        | 00110        | Bit [31:15] of region start address |
| 64KB        | 00111        | Bit [31:16] of region start address |
| 128KB       | 01000        | Bit [31:17] of region start address |
| 256KB       | 01001        | Bit [31:18] of region start address |
| 512KB       | 01010        | Bit [31:19] of region start address |
| 1MB         | 01011        | Bit [31:20] of region start address |
| 2MB         | 01100        | Bit [31:21] of region start address |
| 4MB         | 01101        | Bit [31:22] of region start address |
| 8MB         | 01110        | Bit [31:23] of region start address |
| 16MB        | 01111        | Bit [31:24] of region start address |
| 32MB        | 10000        | Bit [31:25] of region start address |
| 64MB        | 10001        | Bit [31:26] of region start address |

## 17. Auxiliary ADC Unit

MT7682 features an auxiliary ADC (AUXADC) unit with four channels to measure external channels and a 12-bit Successive Approximation Register (SAR) ADC. The SAR ADC waveform is shown in Figure 16.5-1.



Figure 16.5-1. SAR ADC waveform

### 17.1. Features

- 1) Immediate mode.

There are four channels for external channel use in immediate mode. The AUXADC measures the values only once when the flag of the channel in the AUXADC\_CON1 register is set. The value sampled for channel 0 is stored in register AUXADC\_DATA0, and the value for channel 1 is stored in register AUXADC\_DATA1, and so on.

- 2) Zero-consumption-voltage (ZCV) mode.

There is only one channel for external channel use in ZCV mode. This channel measures voltage automatically to monitor battery power during power up and wake up.

### 17.2. Block diagram

The block diagram for the AUXADC is shown in Figure 17.2-1.



**Figure 17.2-1. AUXADC block diagram**

### 17.3. Functions

#### 1) Immediate mode.

The AUXADC measures values once only when the flag of the channel in the AUXADC\_CON1 register is set. For example, if the value in AUXADC\_CON1 is set, the AUXADC will sample the data for channel 0. Without configuring AUXADC\_CON4, AUXADC\_CON1 must be cleared and set again to initialize another sampling.

If the AUTOSET flag in register AUXADC\_CON4 is set, the auto-sampling function will be enabled. The A/D converter then samples the data for the specified channel. When the data register AUXADC\_DATA0 is read, the A/D converter immediately samples the next value for channel 0.

If multiple channels are selected at the same time, the task will be performed sequentially on every selected channel. For example, if AUXADC\_CON1 is set to 0xf, if 4 channels are selected, the state machine in the unit will start sampling from channel 3 to channel 0 and save the values of each input channel in respective registers.

#### 2) Zero-consumption-voltage (ZCV) mode

There is only one channel for external channels in ZCV mode. This channel only measures voltage automatically during power up and wake up. Set AUXADC\_ZCV\_BYPASS to 1, to prevent default automatic measurements after wake up. The ZCV data will be saved into AUXADC\_DATA\_ZCV.

**Table 17.3-1. AUXADC channel description**

| AUXADC Channel ID | Description                            |
|-------------------|----------------------------------------|
| Channel 0         | External (immediate mode)              |
| Channel 1         | External (immediate mode and ZCV mode) |
| Channel 2         | External (immediate mode)              |
| Channel 3         | External (immediate mode)              |

### 17.4. Programming sequence

#### 1) Immediate mode:

Immediate mode sampling is accomplished by programming AUXADC\_CON1 with the channels to be sampled.

- Sample data after selecting the channel.
- Wait for AUXADC\_CON3 [0]: ADC\_STAT to change from 1 (busy) to 0 (idle).

It is required to program AUXADC\_CON1 back to 0 before sampling again. The immediate mode programming sequence is summarized in Figure 17.4-1.



**Figure 17.4-1. Immediate mode programming sequence**

Note: to disable the AUXADC, turn off digital clock (`ANA_EN_CON[0] = 0`) first and turn off analog power (`MACRO_CON2[0]=0`) in the end.

## 2) Zero-consumption-voltage (ZCV) mode:

There is only one channel for external channels in ZCV mode. This channel only measures voltage automatically during power up and wake up. There is no need to control the ZCV programming sequence. However, it is possible to control the measurement of next wake up by programming `AUXADC_ZCV_BYPASS`.

Note: To use ZCV feature, do not disable the clock, otherwise the ZCV feature will not work for next wakeup.

## 17.5. Register mapping

Module name: AUXADC Base address: (+ao12000oh)

| Address  | Name                   | Width (bits) | Register Functionality                   |
|----------|------------------------|--------------|------------------------------------------|
| Ao120004 | <u>AUXADC CON1</u>     | 16           | Configure the channel in immediate mode. |
| Ao120008 | <u>AUXADC CON3</u>     | 16           | Configure reset and read status.         |
| Ao12000C | <u>AUXADC CON4</u>     | 16           | Configure auto-set.                      |
| Ao120010 | <u>AUXADC DATAo</u>    | 16           | Channel 0 data                           |
| Ao120014 | <u>AUXADC DATA1</u>    | 16           | Channel 1 data                           |
| Ao120018 | <u>AUXADC DATA2</u>    | 16           | Channel 2 data                           |
| Ao12001C | <u>AUXADC DATA3</u>    | 16           | Channel 3 data                           |
| Ao120050 | <u>AUXADC DATA ZCV</u> | 16           | ZCV channel data                         |
| Ao120074 | <u>MACRO CON2</u>      | 16           | Configure analog control.                |
| Ao120078 | <u>ANA EN CON</u>      | 16           | Configure digital clock.                 |

**Ao120004 AUXADC CON1** Configure the channel in immediate mode 0oooooooooooo

|             |         |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------------|---------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Bit Name    | 15      | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| AUXADC_CON1 |         |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type        | RW      |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset       | 0 0 0 0 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit(s) | Name        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0    | AUXADC_CON1 | <b>Bit 0 : Channel 0 immediate mode</b> <ul style="list-style-type: none"> <li>0: The channel is not selected.</li> <li>1: The channel is selected.</li> </ul> <b>Bit 1 : Channel 1 immediate mode</b> <ul style="list-style-type: none"> <li>0: The channel is not selected.</li> <li>1: The channel is selected.</li> </ul> <b>Bit 2 : Channel 2 immediate mode</b> <ul style="list-style-type: none"> <li>0: The channel is not selected.</li> <li>1: The channel is selected.</li> </ul> <b>Bit 3 : Channel 3 immediate mode</b> <ul style="list-style-type: none"> <li>0: The channel is not selected.</li> <li>1: The channel is selected.</li> </ul> |

**Ao120008 AUXADC CON3** Configure the reset and read status 0oooooooooooo

|          |    |    |    |    |    |    |   |                          |   |   |   |   |   |   |   |                          |
|----------|----|----|----|----|----|----|---|--------------------------|---|---|---|---|---|---|---|--------------------------|
| Bit Name | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8<br>SO<br>FT<br>R<br>ST | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0<br>AD<br>C<br>ST<br>AT |
|----------|----|----|----|----|----|----|---|--------------------------|---|---|---|---|---|---|---|--------------------------|

| Type   |  |  |  |  |  |  |  | RW |  |  |  |  |  |  |  | RO |
|--------|--|--|--|--|--|--|--|----|--|--|--|--|--|--|--|----|
| Rese t |  |  |  |  |  |  |  | o  |  |  |  |  |  |  |  | o  |

| Bit(s) | Name     | Description                                                                                                                                                                                                 |
|--------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8      | SOFT_RST | <b>Software reset AUXADC state machine</b> <ul style="list-style-type: none"> <li>• o: Default value</li> <li>• 1: Reset the AUXADC state machine<br/>Set to 1 then clear again to finish reset.</li> </ul> |
| 0      | ADC_STAT | <b>Defines the state of the module</b> <ul style="list-style-type: none"> <li>• o: Idle.</li> <li>• 1: Busy.</li> </ul>                                                                                     |

| <b>Ao12000C AUXADC_CON4</b> |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>Configure the auto set</b> |  |  |  |
|-----------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-------------------------------|--|--|--|
| Bit                         | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | o                             |  |  |  |
| Name                        |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | AU TO SE T                    |  |  |  |
| Type                        |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |                               |  |  |  |
| Rese t                      |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |                               |  |  |  |

| Bit(s) | Name    | Description                                                                                                                                                      |
|--------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | AUTOSET | Defines the auto-sampling mode of the module. In this mode, each channel starts sampling immediately without configuring the control register AUXADC_CON1 again. |

| <b>Ao120010 AUXADC_DATAo</b> |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>Channel 0 data</b> |   |   |  |
|------------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----------------------|---|---|--|
| Bit                          | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | o                     |   |   |  |
| Name                         |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | AUXADC_DATAo          |   |   |  |
| Type                         |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RO                    |   |   |  |
| Rese t                       |    |    |    |    |    |    |   | o | o | o | o | o | o | o | o | o                     | o | o |  |

| Bit(s) | Name         | Description                 |
|--------|--------------|-----------------------------|
| 11:0   | AUXADC_DATAo | Sampled data for channel 0. |

| <b>Ao120014 AUXADC_DATA1</b> |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>Channel 1 data</b> |   |   |  |
|------------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----------------------|---|---|--|
| Bit                          | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | o                     |   |   |  |
| Name                         |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | AUXADC_DATA1          |   |   |  |
| Type                         |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RO                    |   |   |  |
| Rese t                       |    |    |    |    |    |    |   | o | o | o | o | o | o | o | o | o                     | o | o |  |

| Bit(s) | Name         | Description                 |
|--------|--------------|-----------------------------|
| 11:0   | AUXADC_DATA1 | Sampled data for channel 1. |

**Ao120018 AUXADC DATA2 Channel 2 data 00000000**

| Bit Name | 15           | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----------|--------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Type     | AUXADC_DATA2 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset    | RO           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 0        | 0            | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

**Bit(s) Name Description**

11:0      AUXADC\_DATA2      Sampled data for channel 2.

**Ao12001C AUXADC DATA3 Channel 3 data 00000000**

| Bit Name | 15           | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----------|--------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Type     | AUXADC_DATA3 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset    | RO           |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 0        | 0            | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

**Bit(s) Name Description**

11:0      AUXADC\_DATA3      Sampled data for channel 3.

**Ao120050 AUXADC DATA\_ZCV ZCV\_channel 00000000**

| Bit Name | 15              | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----------|-----------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Type     | AUXADC_DATA_ZCV |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset    | RO              |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 0        | 0               | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

**Bit(s) Name Description**

11:0      AUXADC\_DATA\_ZCV      Sampled data for ZCV channel

**Ao120074 MACRO CON2 Configure the analog control 00000400**

| Bit Name | 31            | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16               |
|----------|---------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------|
| Type     |               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                  |
| Reset    |               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                  |
| Bit      | 15            | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                |
| Name     | RG_AUXADC_LDO |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RG_AUXADC_LDO_EN |
| Type     | RW            |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW               |
| Reset    | 0             |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0                |

| Bit(s) | Name             | Description                                                                                                                                                                                                                                                        |
|--------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:8   | RG_AUXADC_LDO    | <ul style="list-style-type: none"> <li>4'b0000 : 2.4V</li> <li>4'b0001 : 2.425V</li> <li>4'b0010 : 2.45V</li> <li>4'b0011 : 2.475V</li> <li>4'b0100 : 2.5V (default value)</li> <li>4'b0101 : 2.525V</li> <li>4'b0110 : 2.55V</li> <li>4'b0111 : 2.575V</li> </ul> |
| 0      | RG_AUXADC_LDO_EN | Enables the AUXADC analog power.                                                                                                                                                                                                                                   |

| <b>A0120078 ANA_EN_CON</b> |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>Configure the digital clock</b> |                          |  |  | <b>oooooooooo</b> |  |  |  |  |  |  |  |
|----------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|------------------------------------|--------------------------|--|--|-------------------|--|--|--|--|--|--|--|
| <b>Bit</b>                 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                                  | AU<br>XA<br>DC<br>E<br>N |  |  |                   |  |  |  |  |  |  |  |
| <b>Name</b>                |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW                                 |                          |  |  |                   |  |  |  |  |  |  |  |
| <b>Type</b>                |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |                                    |                          |  |  |                   |  |  |  |  |  |  |  |
| <b>Reset</b>               |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 0                                  |                          |  |  |                   |  |  |  |  |  |  |  |

| Bit(s) | Name      | Description               |
|--------|-----------|---------------------------|
| 0      | AUXADC_EN | Enables the AUXADC clock. |

## 18. Reset Generation Unit

MediaTek MT7682 reset generation unit (RGU) provides three types of resets: hardware reset, watchdog reset and software reset:

- Hardware reset. This reset is input through the xreset\_rstb pin, which is driven low during PMU power-on. The hardware reset has a global effect on the chip: all digital and analog circuits are initialized.
- Watchdog reset. The watchdog reset is generated when the watchdog timer expires. CMSYS, CONNSYS, CONNSYS\_CPU, SDCTL and INFRASYS are affected by the watchdog reset.
- Software reset. Software resets are local reset signals that initialize specific hardware components. Subsystems with this feature are CONNSYS, CONNSYS\_CPU and SDCTL.

### 18.1. Features

- Watchdog timer (WDT) time out length and interval time can be configured by registers WDT\_LENGTH and WDT\_INTERVAL.
- The reset generation unit includes four external trigger sources: xreset\_rstb, JTAG\_rstb, AIRCR\_rstb (from Cortex M4) and PCM\_wdt\_rstb (from power control management). The latter three signals can be masked independently by registers MODULE0\_RST\_MASK, MODULE1\_RST\_MASK and MODULE2\_RST\_MASK.
- AIRCR\_rstb reset source can be extended by register AIRCR\_RST\_INTERVAL for special applications.
- Each register can be protected by corresponding keys to avoid unexpected register settings.
- The RGU includes six retention flags and six retention data, these registers will only be reset by hardware reset (xreset\_rstb).

### 18.2. Block diagram



Figure 18.2-1. Block diagram of RGU

### 18.3. WDT timeout and interval source

The WDT timeout length is generated by a 16-bit counter and the counter clock period is 15.625 ms. The WDT interval time is generated by a 16-bit counter and the counter clock period is 3.05 us. The detailed diagram is shown in Figure 18.3-1.



**Figure 18.3-1. WDT timeout length and interval time**

The AIRCR reset extender is an 8-bit counter, and the counter clock period is 3.05  $\mu$ s. The operation range of the AIRCR interval extender is from 0 to 7.78  $\mu$ s.

## 18.4. Register mapping

**Module name:** RGU Base address: (+A2090000h)

| Address  | Name                       | Width (bits) | Register Functionality                          |
|----------|----------------------------|--------------|-------------------------------------------------|
| A2090000 | <b>WDT_EN</b>              | 32           | <b>Watchdog Timer Enable Register</b>           |
| A2090004 | <b>WDT_LENGTH</b>          | 32           | <b>Watchdog Length Register</b>                 |
| A2090008 | <b>WDT_INTERVAL</b>        | 32           | <b>Watchdog Interval Register</b>               |
| A209000C | <b>WDT_SW_RESTART</b>      | 32           | <b>Watchdog Timer Software Restart Register</b> |
| A2090010 | <b>WDT_SW_RST</b>          | 32           | <b>Watchdog Timer Software Reset Register</b>   |
| A2090014 | <b>WDT_AUTO_RESTART_EN</b> | 32           | <b>Watchdog Timer Auto Restart Register</b>     |
| A2090018 | <b>WDT_IE</b>              | 32           | <b>Watchdog Timer Interrupt Enable Register</b> |
| A209001C | <b>WDT_INT</b>             | 32           | <b>Watchdog Timer Interrupt Register</b>        |
| A2090020 | <b>WDT_STA</b>             | 32           | <b>Watchdog Timer Status Register</b>           |
| A2090024 | <b>SW_RST0</b>             | 32           | <b>Software Reset 0 Register</b>                |
| A2090028 | <b>SW_RST1</b>             | 32           | <b>Software Reset 1 Register</b>                |
| A209002C | <b>RST_MASK0</b>           | 32           | <b>Reset Mask 0 Register</b>                    |
| A2090030 | <b>RST_MASK1</b>           | 32           | <b>Reset Mask 1 Register</b>                    |
| A2090034 | <b>AIRCR_RST_INTERVAL</b>  | 32           | <b>AIRCR Reset Interval Register</b>            |
| A2090038 | <b>RETN_FLAG0</b>          | 32           | <b>Retention Flag 0 Register</b>                |
| A209003C | <b>RETN_FLAG1</b>          | 32           | <b>Retention Flag 1 Register</b>                |
| A2090040 | <b>RETN_FLAG2</b>          | 32           | <b>Retention Flag 2 Register</b>                |
| A2090044 | <b>RETN_FLAG3</b>          | 32           | <b>Retention Flag 3 Register</b>                |
| A2090048 | <b>RETN_FLAG4</b>          | 32           | <b>Retention Flag 4 Register</b>                |
| A209004C | <b>RETN_FLAG5</b>          | 32           | <b>Retention Flag 5 Register</b>                |
| A2090050 | <b>RETN_DATA0</b>          | 32           | <b>Retention Data 0 Register</b>                |
| A2090054 | <b>RETN_DATA1</b>          | 32           | <b>Retention Data 1 Register</b>                |
| A2090058 | <b>RETN_DATA2</b>          | 32           | <b>Retention Data 2 Register</b>                |
| A209005C | <b>RETN_DATA3</b>          | 32           | <b>Retention Data 3 Register</b>                |
| A2090060 | <b>RETN_DATA4</b>          | 32           | <b>Retention Data 4 Register</b>                |
| A2090064 | <b>RETN_DATA5</b>          | 32           | <b>Retention Data 5 Register</b>                |

A2090000      WDT\_EN      Watchdog Timer Enable Register      00000100

| <b>Bit</b>   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24             | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|----|----|----|----|----|----|----|----------------|----|----|----|----|----|----|----|----|
| <b>Name</b>  |    |    |    |    |    |    |    |                |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |                |    |    |    |    |    |    |    |    |
| <b>Reset</b> |    |    |    |    |    |    |    |                |    |    |    |    |    |    |    |    |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8              | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  |    |    |    |    |    |    |    | <b>WD_T_EN</b> |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    | <b>RW</b>      |    |    |    |    |    |    |    |    |
| <b>Reset</b> |    |    |    |    |    |    |    | 1              | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**Bit(s)**    **Name**      **Description**

8      WDT\_EN      **Watchdog timer enable**

0: Disable watchdog timer  
1: Enable watchdog timer

7:0      KEY      **Configure WDT enable register, if KEY= 8'h11.**

A2090004      WDT\_LENGTH      Watchdog Length Register      07FF0000

| <b>Bit</b>   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    | 0  | 0  | 0  | 0  | 0  |

**Bit(s)**    **Name**      **Description**

31:16      WDT\_LENGTH      **Watchdog timer length**

The counter unit length is 15.625 ms.

7:0      KEY      **Configure WDT length, if KEY= 8'h12.**

A2090008      WDT\_INTERVAL      Watchdog Interval Register      OFFFF0000

AL

| <b>Bit</b>   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    | 0  | 0  | 0  | 0  | 0  |

**Bit(s)**    **Name**      **Description**

31:16      WDT\_INTERVAL      **Watchdog timer interval**

Indicates reset duration when watchdog timer timeout occurs. However, the register will not be valid when WDT\_IE is 1.

The interval counter unit is 3.05 µs.

7:0      KEY      **Configure WDT interval, if KEY= 8'h13.**

A209000C WDT\_SW\_RES Watchdog Timer Software Restart Register 00000000  
TART

| Bit          | 31                | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|-------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  | <b>KEY[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | WO                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>   | 15                | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | <b>KEY[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | WO                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name | Description                                                                                       |
|--------|------|---------------------------------------------------------------------------------------------------|
| 31:0   | KEY  | <b>Watchdog timer software restart</b><br>Software restart watchdog timer, if KEY = 32'h1456789a. |

A2090010 WDT\_SW\_RST Watchdog Timer Software Reset Register 00000000

| Bit          | 31                | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|-------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  | <b>KEY[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | WO                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>   | 15                | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | <b>KEY[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | WO                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name | Description                                                                                          |
|--------|------|------------------------------------------------------------------------------------------------------|
| 31:0   | KEY  | <b>Watchdog timer software reset</b><br>Software trigger watchdog timer reset, if KEY= 32'h156789ab. |

A2090014 WDT\_AUTO\_RST Watchdog Timer Auto Restart Register 00000000  
ESTART\_EN

| Bit          | 31                             | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|--------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  |                                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |                                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |                                |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Bit</b>   | 15                             | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | <b>WD_T_AUTO_TO_RST_ENABLE</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW                             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |                                |    |    |    |    |    |    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name                | Description                                                                                                                    |
|--------|---------------------|--------------------------------------------------------------------------------------------------------------------------------|
| 8      | WDT_AUTO_RESTART_EN | <b>Watchdog timer automatic restart enable</b><br>Hardware auto restart after watch dog timer reset<br>0: Disable<br>1: Enable |
| 7:0    | KEY                 | <b>Configure WDT automatic restart enable register, if KEY= 8'h16.</b>                                                         |

A2090018      WDT\_IE      Watchdog Timer Interrupt Enable Register      00000000

| <b>Bit</b>   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24                      | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|----|----|----|----|----|----|----|-------------------------|----|----|----|----|----|----|----|----|
| <b>Name</b>  |    |    |    |    |    |    |    |                         |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |                         |    |    |    |    |    |    |    |    |
| <b>Reset</b> |    |    |    |    |    |    |    |                         |    |    |    |    |    |    |    |    |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8                       | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  |    |    |    |    |    |    |    | <b>WD<br/>T_I<br/>E</b> |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    | <b>RW</b>               |    |    |    |    |    |    |    |    |
| <b>Reset</b> |    |    |    |    |    |    |    | 0                       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                                                               |
|---------------|-------------|--------------------------------------------------------------------------------------------------|
| 8             | WDT_IE      | <b>Watchdog timer interrupt enable</b><br>Issues an interrupt instead of a watchdog timer reset. |
| 7:0           | KEY         | <b>Configure WDT interrupt enable, if KEY= 8'h17.</b>                                            |

A209001C      WDT\_INT      Watchdog Timer Interrupt Register      00000000

| <b>Bit</b>   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17                       | 16        |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------------|-----------|
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                          |           |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                          |           |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                          |           |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1                        | 0         |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>WD<br/>T_I<br/>NT</b> |           |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                          | <b>RC</b> |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                          | 0         |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                                    |
|---------------|-------------|-----------------------------------------------------------------------|
| 0             | WDT_INT     | <b>Watchdog timer interrupt</b><br>WDT interrupt read clear register. |

A2090020      WDT\_STA      Watchdog Timer Status Register      00000000

| <b>Bit</b>   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17             | 16        |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------------|-----------|
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                |           |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                |           |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                |           |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1              | 0         |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>WDT_STA</b> |           |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                | <b>RO</b> |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0              | 0         |

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                        |
|---------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1:0           | WDT_STA     | <b>Watchdog timer status</b><br>[1]: HW_WDT, indicates the cause of watchdog reset.<br>0: Reset not due to watchdog timer.<br>1: Reset due to watchdog timer expired timeout.<br>[0]: SW_WDT, indicates if watchdog timer reset is triggered by software.<br>0: Reset not due to software triggered watchdog timer.<br>1: Reset due to software triggered watchdog timer. |

## A2090024 SW\_RST0 Software Reset 0 Register 00000100

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24                                    | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|---------------------------------------|----|----|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    |    | MO<br>DU<br>LE1<br>_S<br>W<br>RS<br>T |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    | RW                                    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    | 0                                     | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8                                     | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    | MO<br>DU<br>LE<br>o_S<br>W<br>RS<br>T |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    | RW                                    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    | 1                                     | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name           | Description                                             |
|--------|----------------|---------------------------------------------------------|
| 24     | MODULE1_SW_RST | CONN SYS CPU SW_RST<br>0: no reset<br>1: invoke a reset |
| 23:16  | KEY1           | Configure CONNSY CPU software reset if KEY= 8'h19       |
| 8      | MODULEo_SW_RST | CONN SYS SW_RST<br>0: no reset<br>1: invoke a reset     |
| 7:0    | KEYo           | Configure CONNSY software reset if KEY= 8'h18           |

## A2090028 SW\_RST1 Software Reset 1 Register 00000000

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24                                    | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|---------------------------------------|----|----|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    |    | MO<br>DU<br>LE3<br>_S<br>W<br>RS<br>T |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    | RW                                    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    | 0                                     | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8                                     | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    | MO<br>DU<br>LE2<br>_S<br>W<br>RS<br>T |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    | RW                                    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    | 0                                     | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name           | Description                 |
|--------|----------------|-----------------------------|
| 24     | MODULE3_SW_RST | Reserved                    |
| 23:16  | KEY1           |                             |
| 8      | MODULE2_SW_RST | SDCTL_SW_RST<br>0: no reset |

|     |      |                                                                     |
|-----|------|---------------------------------------------------------------------|
| 7:0 | KEYO | 1: Invoke a reset<br>Configure SDCTL software reset, if KEY= 8'h1a. |
|-----|------|---------------------------------------------------------------------|

| A209002C RST MASK0 |    |    |    |    |    |    |    |                                               | Reset Mask 0 Register |    |    |    |    |    |    |    |   |
|--------------------|----|----|----|----|----|----|----|-----------------------------------------------|-----------------------|----|----|----|----|----|----|----|---|
| Bit                | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24                                            | 23                    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |   |
| Name               |    |    |    |    |    |    |    | MO<br>DU<br>LE1<br>_R<br>ST<br>_MA<br>SK      | KEY1                  |    |    |    |    |    |    |    |   |
| Type               |    |    |    |    |    |    |    | RW                                            | WO                    |    |    |    |    |    |    |    |   |
| Reset              |    |    |    |    |    |    |    | 1                                             | 0                     | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 |
| Bit                | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8                                             | 7                     | 6  | 5  | 4  | 3  | 2  | 1  | 0  |   |
| Name               |    |    |    |    |    |    |    | MO<br>DU<br>LE<br>_O<br>_RS<br>T<br>_MA<br>SK | KEY0                  |    |    |    |    |    |    |    |   |
| Type               |    |    |    |    |    |    |    | RW                                            | WO                    |    |    |    |    |    |    |    |   |
| Reset              |    |    |    |    |    |    |    | 1                                             | 0                     | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 |

| Bit(s) | Name             | Description                                                                                                           |
|--------|------------------|-----------------------------------------------------------------------------------------------------------------------|
| 24     | MODULE1_RST_MASK | <b>AIRCR reset require mask</b><br>Mask reset source from AIRCR, default enable.<br>0: disable mask<br>1: enable mask |
| 23:16  | KEY1             | <b>Configure AIRCR reset mask, if KEY= 8'h1d.</b>                                                                     |
| 8      | MODULE0_RST_MASK | <b>JTAG reset mask</b><br>Mask reset source from JTAG, default enable.<br>0: disable mask<br>1: enable mask           |
| 7:0    | KEY0             | <b>Configure JTAG reset mask, if KEY= 8'h1c.</b>                                                                      |

| A2090030 RST MASK1 |    |    |    |    |    |    |    |                                          | Reset Mask 1 Register |    |    |    |    |    |    |    |   |
|--------------------|----|----|----|----|----|----|----|------------------------------------------|-----------------------|----|----|----|----|----|----|----|---|
| Bit                | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24                                       | 23                    | 22 | 21 | 20 | 19 | 18 | 17 | 16 |   |
| Name               |    |    |    |    |    |    |    | MO<br>DU<br>LE3<br>_R<br>ST<br>_MA<br>SK | KEY1                  |    |    |    |    |    |    |    |   |
| Type               |    |    |    |    |    |    |    | RW                                       | WO                    |    |    |    |    |    |    |    |   |
| Reset              |    |    |    |    |    |    |    | 1                                        | 0                     | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 |
| Bit                | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8                                        | 7                     | 6  | 5  | 4  | 3  | 2  | 1  | 0  |   |
| Name               |    |    |    |    |    |    |    | MO<br>DU<br>LE2<br>_R<br>ST<br>_MA<br>SK | KEY0                  |    |    |    |    |    |    |    |   |
| Type               |    |    |    |    |    |    |    | RW                                       | WO                    |    |    |    |    |    |    |    |   |
| Reset              |    |    |    |    |    |    |    | 1                                        | 0                     | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 |

| Bit(s) | Name             | Description                                                                                                       |
|--------|------------------|-------------------------------------------------------------------------------------------------------------------|
| 24     | MODULE3_RST_MASK | <b>PMU reset mask</b><br>Mask reset to PMU, default enable.<br>0: disable mask<br>1: enable mask                  |
| 23:16  | KEY1             | <b>Configure PMU reset mask, if KEY= 8'h1f.</b>                                                                   |
| 8      | MODULE2_RST_MASK | <b>PCM reset require mask</b><br>Mask reset source from PCM, default enable.<br>0: disable mask<br>1: enable mask |
| 7:0    | KEY0             | <b>Configure PCM reset mask, if KEY= 8'h1e.</b>                                                                   |

A2090034 AIRCR\_RST\_I  
INTERVAL AIRCR Reset Interval Register 00000700

| Bit          | 31                        | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23         | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|---------------------------|----|----|----|----|----|----|----|------------|----|----|----|----|----|----|----|
| <b>Name</b>  |                           |    |    |    |    |    |    |    |            |    |    |    |    |    |    |    |
| <b>Type</b>  |                           |    |    |    |    |    |    |    |            |    |    |    |    |    |    |    |
| <b>Reset</b> |                           |    |    |    |    |    |    |    |            |    |    |    |    |    |    |    |
| <b>Bit</b>   | 15                        | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7          | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | <u>AIRCR_RST_INTERVAL</u> |    |    |    |    |    |    |    | <b>KEY</b> |    |    |    |    |    |    |    |
| <b>Type</b>  | RW                        |    |    |    |    |    |    |    | WO         |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                         | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 0          | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name               | Description                                                                                                             |
|--------|--------------------|-------------------------------------------------------------------------------------------------------------------------|
| 15:8   | AIRCR_RST_INTERVAL | <b>AIRCR reset interval</b><br>Indicates reset duration when AIRCR is enabled.<br>The interval counter unit is 3.05 us. |
| 7:0    | KEY                | <b>KEY= 8'h21</b>                                                                                                       |

A2090038 RETN\_FLAG0 Retention Flag 0 Register 00000000

| Bit          | 31                | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23         | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|-------------------|----|----|----|----|----|----|----|------------|----|----|----|----|----|----|----|
| <b>Name</b>  |                   |    |    |    |    |    |    |    |            |    |    |    |    |    |    |    |
| <b>Type</b>  |                   |    |    |    |    |    |    |    |            |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0          | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>   | 15                | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7          | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | <u>RETN_FLAG0</u> |    |    |    |    |    |    |    | <b>KEY</b> |    |    |    |    |    |    |    |
| <b>Type</b>  | RW                |    |    |    |    |    |    |    | WO         |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0          | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name       | Description                                                                    |
|--------|------------|--------------------------------------------------------------------------------|
| 31:16  | RETN_FLAG0 | <b>Retention flag 0</b><br>This register will only be reset by hardware reset. |
| 7:0    | KEY        | <b>Configure Retention flag 0 reset mask if KEY= 8'h22</b>                     |

A209003C RETN\_FLAG1 Retention Flag 1 Register 00000000

| Bit          | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

## A209003C RETN\_FLAG1

## Retention Flag 1 Register

00000000

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0   |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----|
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | KEY |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | WO  |
| Reset |    |    |    |    |    |    |   |   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0   |

**Bit(s)**   **Name**   **Description**

31:16    RETN\_FLAG1    **Retention flag 1**  
                         This register will only be reset by hardware reset.

7:0       KEY            **Configure retention flag 1 reset mask, if KEY= 8'h23.**

## A2090040 RETN\_FLAG2

## Retention Flag 2 Register

00000000

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16         |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RETN_FLAG2 |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW         |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0          |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0          |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | KEY        |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | WO         |
| Reset |    |    |    |    |    |    |    |    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0          |

**Bit(s)**   **Name**   **Description**

31:16    RETN\_FLAG2    **Retention flag 2**  
                         This register will only be reset by hardware reset.

7:0       KEY            **Configure retention flag 2 reset mask, if KEY= 8'h24.**

## A2090044 RETN\_FLAG3

## Retention Flag 3 Register

00000000

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16         |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RETN_FLAG3 |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW         |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0          |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0          |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | KEY        |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | WO         |
| Reset |    |    |    |    |    |    |    |    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0          |

**Bit(s)**   **Name**   **Description**

31:16    RETN\_FLAG3    **Retention flag 3**  
                         This register will only be reset by hardware reset.

7:0       KEY            **Configure retention flag 3 reset mask, if KEY= 8'h25.**

## A2090048 RETN\_FLAG4

## Retention Flag 4 Register

00000000

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16         |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RETN_FLAG4 |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW         |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0          |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0          |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | KEY        |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | WO         |
| Reset |    |    |    |    |    |    |    |    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0          |

| Bit(s) | Name       | Description                                                                    |
|--------|------------|--------------------------------------------------------------------------------|
| 31:16  | RETN_FLAG4 | <b>Retention flag 4</b><br>This register will only be reset by hardware reset. |
| 7:0    | KEY        | <b>Configure retention flag 4 reset mask, if KEY= 8'h26.</b>                   |

| A209004C RETN_FLAG5 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Retention Flag 5 Register |   |   |  |
|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------------|---|---|--|
| Bit                 | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                        |   |   |  |
| <b>RETN_FLAG5</b>   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           |   |   |  |
| RW                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           |   |   |  |
| <b>Reset</b>        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           |   |   |  |
| <b>Bit</b>          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                         | 0 | 0 |  |
| <b>Bit</b>          | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                         | 0 | 0 |  |
| <b>KEY</b>          |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           |   |   |  |
| WO                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           |   |   |  |
| <b>Reset</b>        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           |   |   |  |
| <b>Bit</b>          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                         | 0 | 0 |  |

| Bit(s) | Name       | Description                                                                    |
|--------|------------|--------------------------------------------------------------------------------|
| 31:16  | RETN_FLAG5 | <b>Retention flag 5</b><br>This register will only be reset by hardware reset. |
| 7:0    | KEY        | <b>Configure retention flag 5 reset mask, if KEY= 8'h27.</b>                   |

| A2090050 RETN_DAT0      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Retention Data 0 Register |   |   |  |
|-------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------------|---|---|--|
| Bit                     | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                        |   |   |  |
| <b>RETN_DAT0[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           |   |   |  |
| RW                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           |   |   |  |
| <b>Reset</b>            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           |   |   |  |
| <b>Bit</b>              | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                         | 0 | 0 |  |
| <b>RETN_DAT0[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           |   |   |  |
| RW                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           |   |   |  |
| <b>Reset</b>            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           |   |   |  |
| <b>Bit</b>              | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                         | 0 | 0 |  |

| Bit(s) | Name      | Description                                                                    |
|--------|-----------|--------------------------------------------------------------------------------|
| 31:0   | RETN_DAT0 | <b>Retention data 0</b><br>This register will only be reset by hardware reset. |

| A2090054 RETN_DAT1      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | Retention Data 1 Register |   |   |  |
|-------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------------|---|---|--|
| Bit                     | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                        |   |   |  |
| <b>RETN_DAT1[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           |   |   |  |
| RW                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           |   |   |  |
| <b>Reset</b>            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           |   |   |  |
| <b>Bit</b>              | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                         | 0 | 0 |  |
| <b>RETN_DAT1[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           |   |   |  |
| RW                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           |   |   |  |
| <b>Reset</b>            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                           |   |   |  |
| <b>Bit</b>              | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                         | 0 | 0 |  |

| Bit(s) | Name      | Description                                                                    |
|--------|-----------|--------------------------------------------------------------------------------|
| 31:0   | RETN_DAT1 | <b>Retention data 1</b><br>This register will only be reset by hardware reset. |

## A2090058 RETN\_DAT2

## Retention Data 2 Register

00000000

| Bit          | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit          | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

## Bit(s) Name Description

|      |           |                                                                                |
|------|-----------|--------------------------------------------------------------------------------|
| 31:0 | RETN_DAT2 | <b>Retention data 2</b><br>This register will only be reset by hardware reset. |
|------|-----------|--------------------------------------------------------------------------------|

## A209005C RETN\_DAT3

## Retention Data 3 Register

00000000

| Bit          | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit          | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

## Bit(s) Name Description

|      |           |                                                                                |
|------|-----------|--------------------------------------------------------------------------------|
| 31:0 | RETN_DAT3 | <b>Retention data 3</b><br>This register will only be reset by hardware reset. |
|------|-----------|--------------------------------------------------------------------------------|

## A2090060 RETN\_DAT4

## Retention Data 4 Register

00000000

| Bit          | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit          | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

## Bit(s) Name Description

|      |           |                                                                                |
|------|-----------|--------------------------------------------------------------------------------|
| 31:0 | RETN_DAT4 | <b>Retention data 4</b><br>This register will only be reset by hardware reset. |
|------|-----------|--------------------------------------------------------------------------------|

## A2090064 RETN\_DAT5

## Retention Data 5 Register

00000000

| Bit          | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit          | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

## Bit(s) Name Description

|      |           |                                                                                |
|------|-----------|--------------------------------------------------------------------------------|
| 31:0 | RETN_DAT5 | <b>Retention data 5</b><br>This register will only be reset by hardware reset. |
|------|-----------|--------------------------------------------------------------------------------|

---

31:0      RETN\_DAT5

**Retention data 5**

This register will only be reset by hardware reset.

---

## 19. True Random Number Generator

### 19.1. Overview

The True Random Number Generator (TRNG) is a device in power-down domain that generates random numbers from the ring oscillator (RO) outputs. Various types of ROs are adopted, including Hybrid Fibonacci Ring Oscillator (H-FIRO), Hybrid Ring Oscillator (H-RO) and Hybrid Galois Ring Oscillator (H-GARO). Interrupt request (IRQ) is issued once the random data is successfully generated.

### 19.2. Features

- Normal mode. In normal mode, turn on ROs and sample their outputs to generate random numbers. Once the random data is valid, IRQ will be issued.
- Freerun mode. Continuously activates ROs to create interference on the power source. This can be used to help prevent side-channel attacks. IRQ should be masked at this mode.

### 19.3. Block diagram

Figure 19.3-1 shows the block diagram of TRNG. The APB interface controller handles the MCU control signal and activates the TRNG FSM controller to start the generation process (FSM denotes finite state machine). The Ring oscillator core contains seven ROs, and each of them is designed based on a specific polynomial. The random data is derived from these RO outputs. The Von Neumann Extractor is used to balance the 0/1 probability of the random data. This feature can be enabled by TRNG\_CONF (default off). Note that the generated random data are designed for one-time use only, i.e. register TRNG\_DATA will be reset right after the data is accessed by the MCU.



*Figure 19.3-1. TRNG block diagram*

Figure 19.3-2 shows the block diagram of a general RO. It contains an odd number of inverter cores, a multiplexer, and a sample register. The inverter core design is shown in Figure 19.3-3, which consists of a multiplexer, an inverter, and a delay element. The dashed lines shown in both figures denote the oscillation path within the ring

oscillator and the inverter core, respectively. The wire/cell delay on the path is sensitive to PVT (process, voltage, temperature) variation, i.e. the sampled data is unpredictable; this property makes the ring oscillator a perfect choice for entropy source.



**Figure 19.3-2. Ring Oscillator**



**Figure 19.3-3. Inverter Core**

## 19.4. Function description

The fundamental function of the TRNG is to generate random numbers. Figure 19.4-1 shows the operation flow:

- 1) TRNG\_IDLE. The initial state of TRNG. The operating conditions should be set at this stage, for example, the time interval for each FSM state (TRNG\_TIME), or select the RO for random number generation (TRNG\_CONF). Once the configurations are ready, the generation flow can be activated by setting trng\_start in TRNG\_CTRL.
- 2) TRNG\_LATCH. In this state, TRNG starts inner loop oscillation, i.e. the inner loop of inverter core (Figure 1-3) is closed and outer loop of RO (Figure 1-2) is opened. The time interval of this state is controlled by register TRNG\_TIME [15:8].
- 3) TRNG\_UNGATE. TRNG enters outer loop oscillation, i.e. the inner loop of inverter core is opened and outer loop of RO is closed. The time interval of this state is controlled by register TRNG\_TIME [23:16].
- 4) TRNG\_SAMPLE. In this stage, all RO outputs are sampled and XOR-ed to derive one single random bit. Next, the process will go back to TRNG\_LATCH to get another bit, or to TRNG\_IDLE if all the 32-bit random data is valid. Once the generation is done, IRQ will be issued and the status of TRNG\_INT\_SET [0] will be 1. The time interval of this state is controlled by register TRNG\_TIME [31:24].

The Von Neumann Extractor is designed to balance the 0/1 probability of the random data. It first monitors two consecutively generated random bits to determine one valid output bit. The basic rules for valid bit are as follows:

- 1) If the two consecutive random bits are 00, the output bit of the extractor will be invalid (X).
- 2) If the two consecutive random bits are 01, the output bit of the extractor will be 0.
- 3) If the two consecutive random bits are 10, the output bit of the extractor will be 1.

- 4) If the two consecutive random bits are 11, the output bit of the extractor will be invalid (X).

Every even number bit of the extractor output, if it is a valid bit, will be used for the final random data generation. For example, if the original random data is 1110\_1101\_0111\_1011, the probability of 1's is 75%. The corresponding extractor output will be 1XX1\_0X10\_10XX\_X10X. If only even number bits are considered, the result will be X1\_X0\_0X\_1X. By removing the invalid bits, the final obtained random data is 1001 and the probability of 1s is now down to 50%.

This mechanism is time-consuming as many random bits are dropped out during the process. One can set the timeout limit in TRNG\_CONF to constrain the generation time. The default timeout limit is 1024, this means timeout error will be issued after 1024 random bits are generated. Note, that timeout detection is available only when the Von Neumann extractor is enabled.



**Figure 19.4-1. TRNG operation flow**

## 19.5. Programming sequence

The general programming flow is shown below:

- 1) Enable TRNG\_CG\_CLOCK (see the clock setting section, for more details).
- 2) Set TRNG\_TIME to specify the time interval of each state (default 0x08030F01).
- 3) Set TRNG\_CONF [14:8] to select which RO to enable, such as 0x7F.
- 4) Set TRNG\_CTRL [0] to 1 to start TRNG.
- 5) Wait for IRQ or poll TRNG\_INT\_SET [0].
- 6) Read TRNG\_INT\_SET to check IRQ status (bit [0] = 1: successful; bit [1] = 1: timeout).
- 7) Set TRNG\_INT\_CLR to 0 x 0 to clear IRQ status.
- 8) Read out TRNG\_DATA to get 32-bit random data.

- 9) Set TRNG\_CTRL [0] to 0 to stop TRNG.
- 10) Disable TRNG\_CLOCK.

## 19.6. Register mapping

TRNG control/status registers are listed as follows:

**Module name: TRNG Base address: (+A0010000h)**

| Address  | Name                | Width | Register Functionality                           |
|----------|---------------------|-------|--------------------------------------------------|
| A0010000 | <u>TRNG_CTRL</u>    | 32    | This register controls TRNG operation mode.      |
| A0010004 | <u>TRNG_TIME</u>    | 32    | This register controls the timing of each state. |
| A0010008 | <u>TRNG_DATA</u>    | 32    | This register stores the generated random data.  |
| A001000C | <u>TRNG_CONF</u>    | 32    | This register configures RO behavior.            |
| A0010010 | <u>TRNG_INT_SET</u> | 32    | This register stores the IRQ status.             |
| A0010014 | <u>TRNG_INT_CLR</u> | 32    | This register is used to clear the IRQ status.   |

**A0010000 TRNG\_CTRL**

**This register controls TRNG operation 0oooooooooooo mode.**

| Bit          | 31       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17           | 16         |
|--------------|----------|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------|------------|
| <b>Name</b>  | trng_rdy |    |    |    |    |    |    |    |    |    |    |    |    |    |              |            |
| <b>Type</b>  | RO       |    |    |    |    |    |    |    |    |    |    |    |    |    |              |            |
| <b>Reset</b> | 0        |    |    |    |    |    |    |    |    |    |    |    |    |    |              |            |
| Bit          | 15       | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1            | 0          |
| <b>Name</b>  |          |    |    |    |    |    |    |    |    |    |    |    |    |    | trng_freerun | trng_start |
| <b>Type</b>  |          |    |    |    |    |    |    |    |    |    |    |    |    |    | RW           | RW         |
| <b>Reset</b> |          |    |    |    |    |    |    |    |    |    |    |    |    |    | 0            | 0          |

| Bit(s) | Name         | Description                                                                                                                                                                                                                                |
|--------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31     | trng_rdy     | <ul style="list-style-type: none"> <li>This register indicates the status of random number generation           <ul style="list-style-type: none"> <li>o: random data is not ready</li> <li>1: random data is ready</li> </ul> </li> </ul> |
| 1      | trng_freerun | <ul style="list-style-type: none"> <li>This register is used to enable freerun mode           <ul style="list-style-type: none"> <li>o: disable freerun</li> <li>1: enable freerun</li> </ul> </li> </ul>                                  |
| 0      | trng_start   | <ul style="list-style-type: none"> <li>This register is used to start/stop random number generation           <ul style="list-style-type: none"> <li>o: stop generation</li> <li>1: start generation</li> </ul> </li> </ul>                |

**A0010004 TRNG\_TIME**

**This register controls the timing of 03080F01**

each state.

| Bit   | 31         | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23         | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|------------|----|----|----|----|----|----|----|------------|----|----|----|----|----|----|----|
| Name  | sample_cnt |    |    |    |    |    |    |    | ungate_cnt |    |    |    |    |    |    |    |
| Type  | RW         |    |    |    |    |    |    |    | RW         |    |    |    |    |    |    |    |
| Reset | 0          | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 0          | 0  | 0  | 0  | 1  | 0  | 0  | 0  |
| Bit   | 15         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7          | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | latch_cnt  |    |    |    |    |    |    |    | sysclk_cnt |    |    |    |    |    |    |    |
| Type  | RW         |    |    |    |    |    |    |    | RW         |    |    |    |    |    |    |    |
| Reset | 0          | 0  | 0  | 0  | 1  | 1  | 1  | 1  | 0          | 0  | 0  | 0  | 0  | 0  | 0  | 1  |

| Bit(s) | Name       | Description                                                                       |
|--------|------------|-----------------------------------------------------------------------------------|
| 31:24  | sample_cnt | This register controls the interval of TRNG sample state.                         |
| 23:16  | ungate_cnt | This register controls the interval of TRNG ungate state.                         |
| 15:8   | latch_cnt  | This register controls the interval of TRNG latch state.                          |
| 7:0    | sysclk_cnt | The TRNG operation frequency is equal to the bus frequency divided by SYSCLK_CNT. |

**A0010008 TRNG DATA**      This register stores the generated random data.      **oooooooooooo**

| Bit   | 31        | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|-----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | trng_data |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15        | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | trng_data |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0         | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name      | Description                |
|--------|-----------|----------------------------|
| 31:0   | trng_data | The generated random data. |

| Bit   | 31        | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|-----------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | von_en    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0         | 0  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15        | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | ro_enable |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 1         | 1  | 1  | 1  | 1  | 1  | 1  | 1  |    | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Name           | Description                                                                                                                                                              |
|--------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 28     | von_en         | This register is used to enable the Von-Neumann extractor<br>1: turn on<br>0: turn off                                                                                   |
| 27:16  | time_out_limit | This register sets the timeout limit when the Von-Neumann extractor is enabled. If exceeding the limit, it will issue a timeout interrupt. (default: timeout after 1024) |

|      |               |                                                                                                                                                                                                                                                                                                               |
|------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |               | <b>sample cycles)</b>                                                                                                                                                                                                                                                                                         |
| 14:8 | ro_enable     | <b>Ring oscillator enable for RNG</b>                                                                                                                                                                                                                                                                         |
|      |               | <ul style="list-style-type: none"> <li>• Bit[0] = 1: Enable H-FIRO</li> <li>• Bit[1] = 1: Enable H-RO</li> <li>• Bit[2] = 1: Enable H-GARO</li> <li>• Bit[3] = 1: Enable H-GARO2</li> <li>• Bit[4] = 1: Enable H-GARO3</li> <li>• Bit[5] = 1: Enable H-GARO4</li> <li>• Bit[6] = 1: Enable H-GARO5</li> </ul> |
| 6:0  | ro_output_sel | <b>Select RO output for debug (debug only)</b>                                                                                                                                                                                                                                                                |
|      |               | <ul style="list-style-type: none"> <li>• 7'booo_0001: H-FIRO</li> <li>• 7'booo_0010: H-RO</li> <li>• 7'booo_0100: H-GARO</li> <li>• 7'booo_1000: H-GARO2</li> <li>• 7'bo01_0000: H-GARO3</li> <li>• 7'bo10_0000: H-GARO4</li> <li>• 7'b100_0000: H-GARO5</li> </ul>                                           |

**A0010010 TRNG INT SET**

**This register stores the IRO status.**

00000000

| <b>Bit(s)</b> | <b>Name</b>  | <b>Description</b>                                               |
|---------------|--------------|------------------------------------------------------------------|
| 1             | timeout_fail | This register indicates TRNG timeout failure.                    |
| 0             | trng_done    | This register indicates random number generation was successful. |

**A0010014 TRNG INT CLR**

## This register

This register indicates TRNG timeout failure.

**This register is used to clear the IRO**

00000000

| <b>Bit(s)</b> | <b>Name</b> | <b>Description</b> |
|---------------|-------------|--------------------|
|---------------|-------------|--------------------|

---

31:0      irq\_clr\_wrProgram this register with any value to reset the IRQ status.

---

## 20. Real Time Clock (RTC)

The Real-Time Clock (RTC) module provides time and data information, as well as 32.768kHz (32K) clock. The clock is selected between three clock sources: one external (XOSC32) and two internal (XO\_DIV32, EOSC32). A strapping bit, SLOW\_SRC\_B, is added for the 32K crystal existence information. The clock source is from the external oscillator when SLOW\_SRC\_B is 0.

The RTC block has an independent power supply. When the chip is in retention mode, a dedicated regulator supplies power to the RTC block. In addition to providing timing data, an alarm interrupt is generated and can be used to power up the baseband core. Regular interrupts corresponding to seconds, minutes, hours and days can be generated whenever the time counter value reaches a maximum value (e.g. 59 for seconds and minutes, 23 for hours, etc.). The year span is supported up till 2127. The maximum day-of-month values, which depend on the leap year condition, are stored in the RTC block.

### 20.1. Features

- There is one real time timer, one alarm timer and a dedicated EINT channel in the RTC.
- The RTC can generate wake up events to the Cortex M4, SPM and PMU to wake up the system.
- There are three 32K clock sources, external 32K crystal (XOSC32), internal oscillator (EOSC32) and divided 32K from 26MHz or 40MHz crystal (XO\_DIV32).

### 20.2. Block diagram

The block diagram for the RTC is shown in Figure 20.2-1



*Figure 20.2-1. RTC block diagram*

### 20.3. Functions

- Alarm: RTC can generate wake-up events or interrupts when the real-time timer is the same as the alarm setting.
- Tick: RTC can generate wake-up events or interrupts when the timer reaches the maximum timeout value.
- 32K source: RTC provides 32.768kHz clock from external crystal or internal oscillator.

### 20.4. Programming sequence

Apply the following sequence to modify the registers:

- 1) Write registers to be modified.
- 2) Write WRTGR to 1 to trigger data transfer from bus to the RTC.
- 3) Wait for CBUSY to go low before the next operation.

### 20.5. Register mapping

**Module name: RTC** Base address: (+a2080000h)

| Address  | Name               | Width (bits) | Register Function |
|----------|--------------------|--------------|-------------------|
| A2080004 | <u>RTC IRQ STA</u> | 16           | RTC IRQ status    |
| A2080008 | <u>RTC IRQ EN</u>  | 16           | RTC IRQ enable    |

| Address  | Name                 | Width (bits) | Register Function                         |
|----------|----------------------|--------------|-------------------------------------------|
| A208000C | <u>RTC_CII_EN</u>    | 16           | Counter increment IRQ enable              |
| A2080010 | <u>RTC_AL_MASK</u>   | 16           | RTC alarm mask                            |
| A2080014 | <u>RTC_TCo</u>       | 16           | RTC time counter register0                |
| A2080018 | <u>RTC_TC1</u>       | 16           | RTC time counter register1                |
| A208001C | <u>RTC_TC2</u>       | 16           | RTC time counter register2                |
| A2080020 | <u>RTC_TC3</u>       | 16           | RTC time counter register3                |
| A2080024 | <u>RTC_AL0</u>       | 16           | RTC alarm setting register0               |
| A2080028 | <u>RTC_AL1</u>       | 16           | RTC alarm setting register1               |
| A208002C | <u>RTC_AL2</u>       | 16           | RTC alarm setting register2               |
| A2080030 | <u>RTC_AL3</u>       | 16           | RTC alarm setting register3               |
| A2080038 | <u>RTC_NEW_SPARo</u> | 16           | New spare register0 for specific purpose  |
| A208003C | <u>RTC_EINT</u>      | 16           | RTC EINT control                          |
| A2080058 | <u>RTC_PDN0</u>      | 16           | PDNo                                      |
| A208005C | <u>RTC_PDN1</u>      | 16           | PDN1                                      |
| A2080060 | <u>RTC_SPARo</u>     | 16           | Spare register0 for specific purpose      |
| A2080064 | <u>RTC_SPAR1</u>     | 16           | Spare register1 for specific purpose      |
| A208006C | <u>RTC_DIFF</u>      | 16           | One-time calibration offset               |
| A2080070 | <u>RTC_CALI</u>      | 16           | Repeat calibration offset                 |
| A2080074 | <u>RTC_WRTGR</u>     | 16           | Enable the transfers between core and RTC |
| A2080078 | <u>RTC_GPIO_CON</u>  | 16           | GPIO control register                     |

| A2080004 RTC IRQ STA |    |    |    |    |    |    |   |   |   |   |   |   |   |   | RTC IRQ status |    |         |   | 00000000 |  |  |  |
|----------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|----------------|----|---------|---|----------|--|--|--|
| Bit Name             | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1              | 0  | IRQ_STA |   |          |  |  |  |
| Type                 |    |    |    |    |    |    |   |   |   |   |   |   |   |   |                | RC |         |   |          |  |  |  |
| Rese t               |    |    |    |    |    |    |   |   |   |   |   |   |   |   |                | 0  | 0       | 0 | 0        |  |  |  |

| Bit(s) | Mnemonic | Name    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|--------|----------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0    |          | IRQ_STA | <b>RTC IRQ status</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|        |          |         | <ul style="list-style-type: none"> <li>• IRQ_STA[3]: EINT_STA<br/>Indicates the IRQ status and whether the EINT is asserted.           <ul style="list-style-type: none"> <li>◦ 0: No IRQ occurred.</li> <li>◦ 1: IRQ occurred.</li> </ul> </li> <li>• IRQ_STA[2]: LP_STA<br/>Indicates the IRQ status and whether the LPD is asserted.           <ul style="list-style-type: none"> <li>◦ 0: No IRQ occurred; the 32K clock can be used.</li> <li>◦ 1: IRQ occurred; the 32K clock stopped.</li> </ul> </li> <li>• IRQ_STA[1]: TC_STA<br/>Indicates the IRQ status and whether the tick condition is met.           <ul style="list-style-type: none"> <li>◦ 0: No IRQ occurred; the tick condition isn't met.</li> <li>◦ 1: IRQ occurred; the tick condition is met.</li> </ul> </li> <li>• IRQ_STA[0]: AL_STA<br/>Indicates the IRQ status and whether the alarm condition is</li> </ul> |

met.

- 0: No IRQ occurred; the alarm condition isn't met.
- 1: IRQ occurred; the alarm condition is met.

**A2080008 RTC IRQ EN****RTC IRQ enable****oooooooooooo**

| <b>Bit</b>    | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8<br><b>ON<br/>ES<br/>HO<br/>T</b> | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0<br><b>LP<br/>E<br/>N</b> |
|---------------|----|----|----|----|----|----|---|------------------------------------|---|---|---|---|---|---|---|----------------------------|
| <b>Name</b>   |    |    |    |    |    |    |   | RW                                 |   |   |   |   |   |   |   | RW                         |
| <b>Type</b>   |    |    |    |    |    |    |   |                                    |   |   |   |   |   |   |   |                            |
| <b>Rese t</b> |    |    |    |    |    |    |   | 0                                  |   |   |   |   |   |   |   | 0                          |

**Bit(s) Mnemonic****Name****Description**

8                    ONESHOT

- Controls automatic reset of AL\_EN and TC\_EN.

0                    LP\_EN

- Enable the control bit for OSC32 IRQ generation, if low power is detected (32K clock is off).
  - 1'bo: Disable IRQ generations.
  - 1'b1: Enable LPD.

**A208000C RTC CII\_EN****Counter increment IRQ enable****oooooooooooo**

| <b>Bit</b>    | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8<br><b>TC<br/>E<br/>N</b> | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0<br><b>CII_EN</b> |
|---------------|----|----|----|----|----|----|---|----------------------------|---|---|---|---|---|---|---|--------------------|
| <b>Type</b>   |    |    |    |    |    |    |   | RW                         |   |   |   |   |   |   |   | RW                 |
| <b>Rese t</b> |    |    |    |    |    |    |   | 0                          |   |   |   |   |   |   |   | 0                  |

**Bit(s) Mnemonic****Name****Description**

8                    TC\_EN

Enables the control bit for IRQ generation if the tick condition is met.

- Auto reset when ONESHOT is high upon generation of the corresponding IRQ.
  - 1'bo: Disable IRQ generations.
  - 1'b1: Enable the tick time match interrupt.
- This register activates or de-activates the IRQ generation when the TC counter reaches its maximum value.
  - 4'ho: IRQ at each one-eighth of a second update.
  - 4'h1: IRQ at each one-fourth of a second update.
  - 4'h2: IRQ at each one-half of a second update.
  - 4'h3: IRQ at each second update.
  - 4'h4: IRQ at each minute update.
  - 4'h5: IRQ at each hour update.
  - 4'h6: IRQ at each day update.
  - 4'h7: IRQ at each week update.
  - 4'h8: IRQ at each month update.
  - 4'h9: IRQ at each year update.

| A2080010 RTC AL MASK |    |    |    |    |    |    |   | RTC alarm mask |              |   |   |   |   |   |   | oooooooooo |    |  |  |  |  |  |  |
|----------------------|----|----|----|----|----|----|---|----------------|--------------|---|---|---|---|---|---|------------|----|--|--|--|--|--|--|
| Bit                  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8              | AL<br>E<br>N | 7 | 6 | 5 | 4 | 3 | 2 | 1          | 0  |  |  |  |  |  |  |
| Name                 |    |    |    |    |    |    |   |                |              |   |   |   |   |   |   |            |    |  |  |  |  |  |  |
| Type                 |    |    |    |    |    |    |   | RW             |              |   |   |   |   |   |   |            | RW |  |  |  |  |  |  |
| Reset                |    |    |    |    |    |    |   | o              |              |   | o | o | o | o | o | o          | o  |  |  |  |  |  |  |

| Bit(s) | Mnemonic | Name    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------|----------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8      |          | AL_EN   | <p>Enables the control bit for IRQ generation if the alarm condition is met.</p> <ul style="list-style-type: none"> <li>• Auto reset when ONESHOT is high upon generation of the corresponding IRQ.</li> <li>◦ 1'b0: Disable IRQ generations.</li> <li>◦ 1'b1: Enable the alarm time match interrupt.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 6:0    |          | AL_MASK | <p>The alarm condition for alarm IRQ generation depends whether the corresponding bit in this register is masked. Warning: If you set all bits to 1 in RTC_AL_MASK, such as RTC_AL_MASK=0x7f, and AL_EN=1, the alarm will run every second.</p> <ul style="list-style-type: none"> <li>• AL_MASK[6] <ul style="list-style-type: none"> <li>◦ 0: Condition (RTC_TC_YEA = RTC_AL_YEA) is checked to generate the alarm signal.</li> <li>◦ 1: Condition (RTC_TC_YEA = RTC_AL_YEA) is masked, such that the value of RTC_TC_YEA does not affect the alarm IRQ generation.</li> </ul> </li> <li>• AL_MASK[5] <ul style="list-style-type: none"> <li>◦ 0: Condition (RTC_TC_MTH = RTC_AL_MTH) is checked to generate the alarm signal.</li> <li>◦ 1: Condition (RTC_TC_MTH = RTC_AL_MTH) is masked, such that the value of RTC_TC_MTH does not affect the alarm IRQ generation.</li> </ul> </li> <li>• AL_MASK[4] <ul style="list-style-type: none"> <li>◦ 0: Condition (RTC_TC_DOW = RTC_AL_DOW) is checked to generate the alarm signal.</li> <li>◦ 1: Condition (RTC_TC_DOW = RTC_AL_DOW) is masked, such that the value of RTC_TC_DOW does not affect the alarm IRQ generation.</li> </ul> </li> <li>• AL_MASK[3] <ul style="list-style-type: none"> <li>◦ 0: Condition (RTC_TC_DOM = RTC_AL_DOM) is checked to generate the alarm signal.</li> <li>◦ 1: Condition (RTC_TC_DOM = RTC_AL_DOM) is masked, such that the value of RTC_TC_DOM does not affect the alarm IRQ generation.</li> </ul> </li> <li>• AL_MASK[2] <ul style="list-style-type: none"> <li>◦ 0: Condition (RTC_TC_HOU = RTC_AL_HOU) is checked to generate the alarm signal.</li> <li>◦ 1: Condition (RTC_TC_HOU = RTC_AL_HOU) is masked, such that the value of RTC_TC_HOU does not affect the alarm IRQ generation.</li> </ul> </li> <li>• AL_MASK[1] <ul style="list-style-type: none"> <li>◦ 0: Condition (RTC_TC_MIN = RTC_AL_MIN) is checked to generate the alarm signal.</li> </ul> </li> </ul> |

- 1: Condition (RTC\_TC\_MIN = RTC\_AL\_MIN) is masked, such that the value of RTC\_TC\_MIN does not affect the alarm IRQ generation.
- AL\_MASK[0]
  - 0: Condition (RTC\_TC\_SEC = RTC\_AL\_SEC) is checked to generate the alarm signal.
  - 1: Condition (RTC\_TC\_SEC = RTC\_AL\_SEC) is masked, such that the value of RTC\_TC\_SEC does not affect the alarm IRQ generation.

| <b>A2080014 RTC_TC0</b> |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>RTC time counter register0</b> |   |   |   |
|-------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----------------------------------|---|---|---|
| <b>Bit Name</b>         | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                                 |   |   |   |
| <b>Type</b>             | RW |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW                                |   |   |   |
| <b>Rese t</b>           | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                                 | 0 | 0 | 0 |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b> | <b>Description</b>                                                    |
|---------------|-----------------|-------------|-----------------------------------------------------------------------|
| 13:8          |                 | TC_MINUTE   | The minute initial value for the time counter. Range is from 0 to 59. |
| 5:0           |                 | TC_SECOND   | The second initial value for the time counter. Range is from 0 to 59. |

| <b>A2080018 RTC_TC1</b> |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>RTC time counter register1</b> |   |   |   |
|-------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----------------------------------|---|---|---|
| <b>Bit Name</b>         | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                                 |   |   |   |
| <b>Type</b>             | RW |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW                                |   |   |   |
| <b>Rese t</b>           | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                                 | 0 | 0 | 0 |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b> | <b>Description</b>                                                                                                                                                   |
|---------------|-----------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 12:8          |                 | TC_DOM      | Initial value of the day-of-month for the time counter. The range is from 1 to X (28, 29, 30, 31). The maximum value X depends on month and the leap year condition. |
| 4:0           |                 | TC_HOUR     | Initial value of the hour for the time counter. The range is from 0 to 23.                                                                                           |

| <b>A208001C RTC_TC2</b> |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>RTC time counter register2</b> |   |   |   |
|-------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-----------------------------------|---|---|---|
| <b>Bit Name</b>         | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                                 |   |   |   |
| <b>Type</b>             | RW |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW                                |   |   |   |
| <b>Rese t</b>           | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                                 | 0 | 0 | 0 |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b> | <b>Description</b>                                                               |
|---------------|-----------------|-------------|----------------------------------------------------------------------------------|
| 11:8          |                 | TC_MONTH    | Initial value of the month for the time counter. The range is from 1 to 12.      |
| 2:0           |                 | TC_DOW      | Initial value of the day-of-week for the time counter. The range is from 1 to 7. |

**A2080020 RTC\_TC3****RTC time counter register3****oooooooooo**

| Bit Name | 15      | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----------|---------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Type     | TC_YEAR |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Rese t   | RW      |    |    |    |    |    |   |   |   |   |   |   |   |   |   | o |
| 6:0      |         |    |    |    |    |    |   |   |   | o | o | o | o | o | o | o |

**Bit(s) Mnemonic****Name**

| Description                                                                                                                                                                                                                                                                                   |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Initial value of the year for the time counter. The range is from 0 to 127 to represent years 2000 to 2127.                                                                                                                                                                                   |
| Software can bias the year as multiples of 4 for the internal leap-year formula.                                                                                                                                                                                                              |
| Here are 3 examples: 2000-2127, 1972-2099, 1904-2031. To simplify, RTC hardware treats all 4-multiples as leap years. If the range you defined includes a non-leap 4-multiple year (such as 2100), you have to adjust it to the correct date (change February 29th, 2100 to March 1st, 2100). |
| It's suggested to bias the range larger than 1900 and less than 2100 to evade the manual adjustment, such that the bias values are suggested to be in the range [-28,-96], that are (1972-2099) - (1904-2031).                                                                                |
| The formal leap formula:                                                                                                                                                                                                                                                                      |
| if year modulo 400 is 0 then leap                                                                                                                                                                                                                                                             |
| else if year modulo 100 is 0 then no leap                                                                                                                                                                                                                                                     |
| else if year modulo 4 is 0 then leap                                                                                                                                                                                                                                                          |
| else no leap                                                                                                                                                                                                                                                                                  |

**A2080024 RTC\_AL0****RTC alarm setting register0****oooooooooo**

| Bit Name | 15        | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----------|-----------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Type     | AL_MINUTE |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Rese t   | RW        |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 13:8     | o         | o  | o  | o  | o  | o  | o | o |   | o | o | o | o | o | o | o |

**Bit(s) Mnemonic****Name****Description**

|      |           |  |  |  |  |  |                                                                       |  |  |  |  |  |  |  |  |  |
|------|-----------|--|--|--|--|--|-----------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|
| 13:8 | AL_MINUTE |  |  |  |  |  | The minute value of the alarm counter setting. Range is from 0 to 59. |  |  |  |  |  |  |  |  |  |
| 5:0  | AL_SECOND |  |  |  |  |  | The second value of the alarm counter setting. Range is from 0 to 59. |  |  |  |  |  |  |  |  |  |

**A2080028 RTC\_AL1****RTC alarm setting register1****oooooooooo**

| Bit Name | 15     | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----------|--------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Type     | AL_DOM |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Rese t   | RW     |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| 12:8     | o      | o  | o  | o  | o  | o  | o | o |   | o | o | o | o | o | o | o |

**Bit(s) Mnemonic****Name****Description**

|      |        |  |  |  |  |  |                                                                                                         |  |  |  |  |  |  |  |  |  |
|------|--------|--|--|--|--|--|---------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|
| 12:8 | AL_DOM |  |  |  |  |  | The day-of-month value of the alarm counter setting. Range is from 1 to X (28, 29, 30, 31). The maximum |  |  |  |  |  |  |  |  |  |
|------|--------|--|--|--|--|--|---------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|

|     |         |                                                                                                                              |
|-----|---------|------------------------------------------------------------------------------------------------------------------------------|
| 4:0 | AL_HOUR | value X depends on month and the leap year condition.<br>The hour value of the alarm counter setting. Range is from 0 to 23. |
|-----|---------|------------------------------------------------------------------------------------------------------------------------------|

| <b>A208002C RTC AL2</b> |          |    |    | <b>RTC alarm setting register2</b> |    |    |   |   |   |   |   |   |        |   |   | <b>oooooooooo</b> |  |  |  |
|-------------------------|----------|----|----|------------------------------------|----|----|---|---|---|---|---|---|--------|---|---|-------------------|--|--|--|
| <b>Bit Name</b>         | 15       | 14 | 13 | 12                                 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3      | 2 | 1 | 0                 |  |  |  |
| <b>Type</b>             | AL_MONTH |    |    |                                    |    |    |   |   |   |   |   |   | AL_DOW |   |   |                   |  |  |  |
| <b>Type</b>             | RW       |    |    |                                    |    |    |   |   |   |   |   |   | RW     |   |   |                   |  |  |  |
| <b>Rese t</b>           | 0        | 0  | 0  | 0                                  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0      | 0 | 0 | 0                 |  |  |  |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b> | <b>Description</b>                                                        |
|---------------|-----------------|-------------|---------------------------------------------------------------------------|
| 11:8          |                 | AL_MONTH    | The month value of the alarm counter setting. Range is from 1 to 12.      |
| 2:0           |                 | AL_DOW      | The day-of-week value of the alarm counter setting. Range is from 1 to 7. |

| <b>A2080030 RTC AL3</b>            |         |    |    |    |    |    |   |   |   |   |   |   |    |   |   |   |  |
|------------------------------------|---------|----|----|----|----|----|---|---|---|---|---|---|----|---|---|---|--|
| <b>RTC alarm setting register3</b> |         |    |    |    |    |    |   |   |   |   |   |   |    |   |   |   |  |
| <b>oooooooooo</b>                  |         |    |    |    |    |    |   |   |   |   |   |   |    |   |   |   |  |
| <b>Bit Name</b>                    | 15      | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3  | 2 | 1 | 0 |  |
| <b>Type</b>                        | AL_YEAR |    |    |    |    |    |   |   |   |   |   |   | RW |   |   |   |  |
| <b>Rese t</b>                      | 0       | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0  | 0 | 0 | 0 |  |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b> | <b>Description</b>                                                                                       |
|---------------|-----------------|-------------|----------------------------------------------------------------------------------------------------------|
| 6:0           |                 | AL_YEAR     | The year value of the alarm counter setting. Range is from 0 to 127 to represent the years 2000 to 2127. |

| <b>A2080038 RTC NEW SPARo</b>                  |                 |    |    |    |    |    |   |   |   |   |   |   |                 |   |   |   |  |
|------------------------------------------------|-----------------|----|----|----|----|----|---|---|---|---|---|---|-----------------|---|---|---|--|
| <b>New spare register for specific purpose</b> |                 |    |    |    |    |    |   |   |   |   |   |   |                 |   |   |   |  |
| <b>oooooooooo</b>                              |                 |    |    |    |    |    |   |   |   |   |   |   |                 |   |   |   |  |
| <b>Bit Name</b>                                | 15              | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3               | 2 | 1 | 0 |  |
| <b>Type</b>                                    | RTC_NEW_SPARo_1 |    |    |    |    |    |   |   |   |   |   |   | RTC_NEW_SPARo_0 |   |   |   |  |
| <b>Type</b>                                    | RW              |    |    |    |    |    |   |   |   |   |   |   | RW              |   |   |   |  |
| <b>Rese t</b>                                  | 0               | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0               | 0 | 0 | 0 |  |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b>     | <b>Description</b>              |
|---------------|-----------------|-----------------|---------------------------------|
| 15:8          |                 | RTC_NEW_SPARo_1 | Reserved for specific purposes. |
| 7:0           |                 | RTC_NEW_SPARo_0 | Reserved for specific purposes. |

| <b>A208003C RTC EINT</b> |          |    |    |    |    |    |   |   |   |   |   |   |    |   |   |   |  |
|--------------------------|----------|----|----|----|----|----|---|---|---|---|---|---|----|---|---|---|--|
| <b>RTC EINT control</b>  |          |    |    |    |    |    |   |   |   |   |   |   |    |   |   |   |  |
| <b>oooooooooo</b>        |          |    |    |    |    |    |   |   |   |   |   |   |    |   |   |   |  |
| <b>Bit Name</b>          | 15       | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3  | 2 | 1 | 0 |  |
| <b>Type</b>              | EINT_CON |    |    |    |    |    |   |   |   |   |   |   | RW |   |   |   |  |
| <b>Type</b>              | RW       |    |    |    |    |    |   |   |   |   |   |   | RW |   |   |   |  |
| <b>Rese t</b>            | 0        | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0  | 0 | 0 | 0 |  |

| Bit(s) | Mnemonic | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------|----------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0    |          | EINT_CON | <ul style="list-style-type: none"> <li>• EINT_CON[3]: INV_EN           <ul style="list-style-type: none"> <li>◦ 0: active high</li> <li>◦ 1: active low</li> </ul> </li> <li>• EINT_CON[2]: SYNC_EN           <ul style="list-style-type: none"> <li>◦ 0: not synchronized with 32K</li> <li>◦ 1: synchronized with 32K</li> </ul> </li> <li>• EINT_CON[1]: DEB_EN           <ul style="list-style-type: none"> <li>◦ 0: disable debounce</li> <li>◦ 1: enable debounce</li> </ul> </li> <li>• EINT_CON[0]: EINT_EN           <ul style="list-style-type: none"> <li>◦ 0: disable RTC_EINT channel</li> <li>◦ 1: enable RTC_EINT channel</li> </ul> </li> </ul> |

| <b>A2080058 RTC PDNo</b> |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>PDNo</b> |            |   |   |   |   |   |   |   |            |   |   |   |   |   |   | <b>oooooooooooo</b> |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |
|--------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-------------|------------|---|---|---|---|---|---|---|------------|---|---|---|---|---|---|---------------------|---|---|---|---|---|---|---|---|--|--|--|--|--|--|--|
| Bit Name                 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0           | RTC_PDNo_1 |   |   |   |   |   |   |   | RTC_PDNo_0 |   |   |   |   |   |   |                     |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |
| Type                     | RW |    |    |    |    |    |   |   |   |   |   |   |   |   |   |             | RW         |   |   |   |   |   |   |   |            |   |   |   |   |   |   |                     |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |
| Rese t                   | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0           | 0          | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0          | 0 | 0 | 0 | 0 | 0 | 0 | 0                   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |  |  |  |  |  |  |

| Bit(s) | Mnemonic | Name       | Description                                                                            |
|--------|----------|------------|----------------------------------------------------------------------------------------|
| 15:8   |          | RTC_PDNo_1 | The spare registers for software to keep the power-on and power-off state information. |
| 7:0    |          | RTC_PDNo_0 | The spare registers for software to keep the power-on and power-off state information. |

| <b>A208005C RTC PDN1</b> |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>PDN1</b> |            |   |   |   |   |   |   |   |            |   |   |   |   |   |   | <b>oooooooooooo</b> |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |
|--------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-------------|------------|---|---|---|---|---|---|---|------------|---|---|---|---|---|---|---------------------|---|---|---|---|---|---|---|---|--|--|--|--|--|--|--|
| Bit Name                 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0           | RTC_PDN1_1 |   |   |   |   |   |   |   | RTC_PDN1_0 |   |   |   |   |   |   |                     |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |
| Type                     | RW |    |    |    |    |    |   |   |   |   |   |   |   |   |   |             | RW         |   |   |   |   |   |   |   |            |   |   |   |   |   |   |                     |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |
| Rese t                   | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0           | 0          | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0          | 0 | 0 | 0 | 0 | 0 | 0 | 0                   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |  |  |  |  |  |  |

| Bit(s) | Mnemonic | Name       | Description                                                                            |
|--------|----------|------------|----------------------------------------------------------------------------------------|
| 15:8   |          | RTC_PDN1_1 | The spare registers for software to keep the power-on and power-off state information. |
| 7:0    |          | RTC_PDN1_0 | The spare registers for software to keep the power-on and power-off state information. |

| <b>A2080060 RTC SPARo</b> |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | <b>Spare register for specific purpose</b> |             |   |   |   |   |   |   |   |             |   |   |   |   |   |   | <b>oooooooooooo</b> |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |
|---------------------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|--------------------------------------------|-------------|---|---|---|---|---|---|---|-------------|---|---|---|---|---|---|---------------------|---|---|---|---|---|---|---|---|--|--|--|--|--|--|--|
| Bit Name                  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                                          | RTC_SPARo_1 |   |   |   |   |   |   |   | RTC_SPARo_0 |   |   |   |   |   |   |                     |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |
| Type                      | RW |    |    |    |    |    |   |   |   |   |   |   |   |   |   |                                            | RW          |   |   |   |   |   |   |   |             |   |   |   |   |   |   |                     |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  |
| Rese t                    | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0                                          | 0           | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0           | 0 | 0 | 0 | 0 | 0 | 0 | 0                   | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |  |  |  |  |  |  |

| Bit(s) | Mnemonic | Name        | Description                     |
|--------|----------|-------------|---------------------------------|
| 15:8   |          | RTC_SPARo_1 | Reserved for specific purposes. |
| 7:0    |          | RTC_SPARo_0 | Reserved for specific purposes. |

| <b>A2080064 RTC SPAR1</b> |    |    |    |    |    |    |   |   |   |             |    |   |   |   |   | <b>Spare register1 for specific purpose</b> |   |   |   |   |
|---------------------------|----|----|----|----|----|----|---|---|---|-------------|----|---|---|---|---|---------------------------------------------|---|---|---|---|
| Bit Name                  | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6           | 5  | 4 | 3 | 2 | 1 | 0                                           |   |   |   |   |
| RTC_SPAR1_1               |    |    |    |    |    |    |   |   |   | RTC_SPAR1_0 |    |   |   |   |   |                                             |   |   |   |   |
| Type                      | RW |    |    |    |    |    |   |   |   |             | RW |   |   |   |   |                                             |   |   |   |   |
| Reset                     | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0           | 0  | 0 | 0 | 0 | 0 | 0                                           | 0 | 0 | 0 | 0 |

| Bit(s) | Mnemonic | Name        | Description                     |
|--------|----------|-------------|---------------------------------|
| 15:8   |          | RTC_SPAR1_1 | Reserved for specific purposes. |
| 7:0    |          | RTC_SPAR1_0 | Reserved for specific purposes. |

| <b>A208006C RTC DIFF</b> |    |    |    |    |    |    |   |   |   |          |    |   |   |   |   | <b>One-time calibration offset</b> |   |   |   |   |
|--------------------------|----|----|----|----|----|----|---|---|---|----------|----|---|---|---|---|------------------------------------|---|---|---|---|
| Bit Name                 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6        | 5  | 4 | 3 | 2 | 1 | 0                                  |   |   |   |   |
| RTC_DIFF                 |    |    |    |    |    |    |   |   |   | RTC_DIFF |    |   |   |   |   |                                    |   |   |   |   |
| Type                     | RW |    |    |    |    |    |   |   |   |          | RW |   |   |   |   |                                    |   |   |   |   |
| Reset                    | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0        | 0  | 0 | 0 | 0 | 0 | 0                                  | 0 | 0 | 0 | 0 |

| Bit(s) | Mnemonic | Name     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------|----------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11:0   |          | RTC_DIFF | <b>Adjusts internal counter of RTC. It operates once and returns to 0 when complete.</b><br><br>In some cases, you observe the RTC is faster or slower than the standard. Changing RTC_TC_SEC is coarse and may cause alarm problems. RTC_DIFF provides a finer time unit. An internal 15-bit counter accumulates in each 32768kHz clock. Entering a non-zero value into the RTC_DIFF will cause the internal RTC counter to increase or decrease RTC_DIFF when RTC_DIFF changes to 0 again. RTC_DIFF is in 2's complement.<br><br>For example, if you fill 0xFFFF into RTC_DIFF, the internal counter will decrease by 1 when RTC_DIFF returns to 0. In other words, you can only use RTC_DIFF continuously if RTC_DIFF is 0. |

| <b>A2080070 RTC CALI</b> |    |    |    |    |    |    |   |   |   |          |    |   |   |   |   | <b>Repeat calibration offset</b> |   |   |   |   |
|--------------------------|----|----|----|----|----|----|---|---|---|----------|----|---|---|---|---|----------------------------------|---|---|---|---|
| Bit Name                 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6        | 5  | 4 | 3 | 2 | 1 | 0                                |   |   |   |   |
| RTC_CALI                 |    |    |    |    |    |    |   |   |   | RTC_CALI |    |   |   |   |   |                                  |   |   |   |   |
| Type                     | RW |    |    |    |    |    |   |   |   |          | RW |   |   |   |   |                                  |   |   |   |   |
| Reset                    | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0        | 0  | 0 | 0 | 0 | 0 | 0                                | 0 | 0 | 0 | 0 |

| Bit(s) | Mnemonic | Name     | Description                                                                                                                                                                     |
|--------|----------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14:0   |          | RTC_CALI | <ul style="list-style-type: none"> <li>RTC_CALI[14]: CALI_RW_SEL <ul style="list-style-type: none"> <li>0: Normal RTC_CALI</li> <li>1: K_EOSC32_RTC_CALI</li> </ul> </li> </ul> |

- RTC\_CALI[13:0]: RTC\_CALI\_VALUE  
These registers provide a repeat calibration scheme.  
RTC\_CALI provides two types of calibration.
- 14-bit calibration capability in 8-second duration; in other words, 12-bit calibration capability in each second.  
RTC\_CALI is in 2's complement, such that you can adjust RTC increasing or decreasing.  
Due to the fact that RTC\_CALI is revealed in 8 seconds, the resolution is less than a 1/32768 clock.  
Average resolution:  $1/32768/8=3.81\mu s$   
Average adjustment range: from -31.25 to 31.246 ms/sec  
in 2's complement: -0x2000~0x1FFF  
(-8192~8191)
- 14-bit calibration capability in 1-second duration at K\_EOSC32 mode (K\_EOSC32\_RTC\_CALI); This type of usage is with resolution  $1/32768=30.52\mu s$

**A2080074 RTC\_WRTGR****Enable the transfers between core and RTC**

| Bit    | 15 | 14 | 13 | 12 | 11 | 10      | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0  | WR<br>TG<br>R |
|--------|----|----|----|----|----|---------|---|---|---|---|---|---|---|---|---|----|---------------|
| Name   |    |    |    |    |    | RTC_STA |   |   |   |   |   |   |   |   |   | WO |               |
| Type   |    |    |    |    |    | RO      |   |   |   |   |   |   |   |   |   |    |               |
| Rese t |    |    |    |    |    | 0       | 0 | 0 |   |   |   |   |   |   |   | 0  |               |

**Bit(s) Mnemonic****Name****Description**

10:8

RTC\_STA

- RTC\_STA[2]: RETENTION\_MODE
  - 0: System is not in retention mode.
  - 1: System is in retention mode or woke up from retention mode.
- RTC\_STA[1]: RTC\_INIT\_READY
  - 0: RTC has not been initialized
  - 1: RTC has been initialized
- RTC\_STA[0]: CBUSY
 

When read, this bit indicates whether the read/write channels between RTC/Bus are busy. It will be high after software programs sequence to any of the RTC data registers and enables the transfer by WRTGR = 1 or the reload process.

0

WRTGR

- Enables transfers from core to RTC. After the RTC registers are modified, write WRTGR to 1 to trigger the transfer.
  - The prior writing operations are queued at core power domain. The pending data will not be transferred to RTC domain until WRTGR = 1.
  - After WRTGR = 1, the pending data will be transferred to RTC domain sequentially in order of register address, from low to high.
- For example, RTC\_BBP, RTC\_IRQ\_EN, RTC\_CII\_EN, RTC\_AL\_MASK, RTC\_TC\_SEC, etc.

---

The CBUSY in RTC\_BBPU is 1 in the writing process.  
You can observe CBUSY to determine when the transmission is complete.

---

## 21. General Purpose Inputs/Outputs

### 21.1. Overview

MediaTek MT7682 platform offers 14 general-purpose IO (GPIO) pins. By setting up the control registers, the MCU software can control the direction, the output value and read the input values on these pins. The GPIOs and GPOs are multiplexed with other functions to reduce the pin count.

The clock to send outside the chip is software configurable. There are six clock-out ports and each clock-out can be programmed to output the appropriate clock source. In addition, when two GPIOs function for the same peripheral IP, the smaller GPIO serial number has higher priority over the bigger one.



Figure 21.1-1. GPIO block diagram

### 21.2. IO pull up or down control truth table

Table 21.2-1. GPIO IO structure

|                     |              |                                                             |
|---------------------|--------------|-------------------------------------------------------------|
| <b>IO Structure</b> | <b>TYPE0</b> | Pull-up/down<br>3.63V tolerance                             |
|                     | <b>TYPE1</b> | Pull-up/down<br>5V tolerance                                |
|                     | <b>TYPE2</b> | Pull-up/down<br>5V tolerance<br>SDIO characteristic support |
|                     | <b>TYPE3</b> | Pull-up/down<br>5V tolerance<br>Analog input/output         |

**Table 21.2-2. GPIO versus IO type mapping**

| GPIO Name | IO Type   | GPIO Name | IO Type   |
|-----------|-----------|-----------|-----------|
| GPIO0     | IO TYPE 3 | GPIO13    | IO TYPE 2 |
| GPIO1     | IO TYPE 3 | GPIO14    | IO TYPE 2 |
| GPIO2     | IO TYPE 3 | GPIO15    | IO TYPE 2 |
| GPIO3     | IO TYPE 3 | GPIO16    | IO TYPE 2 |
| GPIO4     | IO TYPE 1 | GPIO17    | IO TYPE 3 |
| GPIO11    | IO TYPE 2 | GPIO21    | IO TYPE 1 |
| GPIO12    | IO TYPE 2 | GPIO22    | IO TYPE 1 |

Refer to the truth table of pull-up/down control for all GPIO pins.

**Table 21.2-3. IO type 1 - pull up/down control**

| GPIO_DIR | GPIO_PU | GPIO_PD | Resistance ( $\Omega$ ) |
|----------|---------|---------|-------------------------|
| 0        | 0       | 0       | High-Z                  |
| 0        | 0       | 1       | Pull-down, 75K          |
| 0        | 1       | 0       | Pull-up, 75K            |
| 0        | 1       | 1       | Keeper, 75K             |
| 1        | 0       | 0       | High-Z                  |

**Table 21.2-4. IO type 2 - pull up/down control**

| GPIO_DIR | GPIO_PUPD | GPIO_R1 | GPIO_R0 | Resistance ( $\Omega$ ) |
|----------|-----------|---------|---------|-------------------------|
| 0        | 0         | 0       | 0       | High-Z                  |
| 0        | 0         | 0       | 1       | Pull-up, 47K            |
| 0        | 0         | 1       | 0       | Pull-up, 47K            |
| 0        | 0         | 1       | 1       | Pull-up, 23.5K          |
| 0        | 1         | 0       | 0       | High-Z                  |
| 0        | 1         | 0       | 1       | Pull-down, 47K          |
| 0        | 1         | 1       | 0       | Pull-down, 47K          |
| 0        | 1         | 1       | 1       | Pull-down, 23.5K        |
| 1        | X         | X       | X       | High-Z                  |

Table 21.2-5. IO type 3 - pull up/down control

| GPIO_DIR | GPIO_G | GPIO_PU | GPIO_PD | Resistance ( $\Omega$ ) |
|----------|--------|---------|---------|-------------------------|
| 0        | 1      | 0       | 0       | High-Z                  |
| 0        | 1      | 0       | 1       | Pull-down, 75K          |
| 0        | 1      | 1       | 0       | Pull-up, 75K            |
| 0        | 1      | 1       | 1       | Keeper, 75K             |
| 1        | 1      | x       | x       | High-Z                  |
| x        | 0      | x       | x       | High-Z                  |

## 21.3. Register mapping

Module name: gpio\_reg Base address: (+A20b0000h)

| Address  | Name                  | Width | Register Function               |
|----------|-----------------------|-------|---------------------------------|
| A20B0000 | <u>GPIO_DIRo</u>      | 32    | <b>GPIO Direction Control</b>   |
| A20B0004 | <u>GPIO_DIRo_SET</u>  | 32    | <b>GPIO Direction Control</b>   |
| A20B0008 | <u>GPIO_DIRo_CLR</u>  | 32    | <b>GPIO Direction Control</b>   |
| A20B0020 | <u>GPIO_DOUTo</u>     | 32    | <b>GPIO Output Data Control</b> |
| A20B0024 | <u>GPIO_DOUTo_SET</u> | 32    | <b>GPIO Output Data Control</b> |
| A20B0028 | <u>GPIO_DOUTo_CLR</u> | 32    | <b>GPIO Output Data Control</b> |
| A20B0030 | <u>GPIO_DINo</u>      | 32    | <b>GPIO Input Data Value</b>    |
| A20B0040 | <u>GPIO_MODEo</u>     | 32    | <b>GPIO Mode Control</b>        |
| A20B0044 | <u>GPIO_MODE1</u>     | 32    | <b>GPIO Mode Control</b>        |
| A20B0048 | <u>GPIO_MODE2</u>     | 32    | <b>GPIO Mode Control</b>        |
| A20B0050 | <u>GPIO_MODEo_SET</u> | 32    | <b>GPIO Mode Control</b>        |
| A20B0054 | <u>GPIO_MODE1_SET</u> | 32    | <b>GPIO Mode Control</b>        |
| A20B0058 | <u>GPIO_MODE2_SET</u> | 32    | <b>GPIO Mode Control</b>        |
| A20B0060 | <u>GPIO_MODEo_CLR</u> | 32    | <b>GPIO Mode Control</b>        |
| A20B0064 | <u>GPIO_MODE1_CLR</u> | 32    | <b>GPIO Mode Control</b>        |
| A20B0068 | <u>GPIO_MODE2_CLR</u> | 32    | <b>GPIO Mode Control</b>        |

Module name: IO\_CFG\_o Base address: (+A20c0000h)

| Address  | Name                | Width | Register Function                                                        |
|----------|---------------------|-------|--------------------------------------------------------------------------|
| A20C0000 | <u>DRV_CFGo</u>     | 32    | <b>GPIO DRV Control</b><br>Configures GPIO driving control               |
| A20C0004 | <u>DRV_CFGo_SET</u> | 32    | <b>GPIO DRV Control</b><br>For bitwise access of DRV_CFGo                |
| A20C0008 | <u>DRV_CFGo_CLR</u> | 32    | <b>GPIO DRV Control</b><br>For bitwise access of DRV_CFGo                |
| A20C0010 | <u>G_CFGo</u>       | 32    | <b>GPIO Analog input Control</b><br>Configures GPIO analog input control |
| A20C0014 | <u>G_CFGo_SET</u>   | 32    | <b>GPIO Analog input Control</b><br>For bitwise access of G_CFGo         |

| Address  | Name                   | Width | Register Function                                                 |
|----------|------------------------|-------|-------------------------------------------------------------------|
| A20C0018 | <u>G_CFGo CLR</u>      | 32    | <b>GPIO Analog input Control</b><br>For bitwise access of G_CFGo  |
| A20C0020 | <u>IES_CFGo</u>        | 32    | <b>GPIO IES Control</b><br>Configures GPIO input enabling control |
| A20C0024 | <u>IES_CFGo SET</u>    | 32    | <b>GPIO IES Control</b><br>For bitwise access of IES_CFGo         |
| A20C0028 | <u>IES_CFGo CLR</u>    | 32    | <b>GPIO IES Control</b><br>For bitwise access of IES_CFGo         |
| A20C0030 | <u>PD_CFGo</u>         | 32    | <b>GPIO PD Control</b><br>Configures GPIO PD control              |
| A20C0034 | <u>PD_CFGo SET</u>     | 32    | <b>GPIO PD Control</b><br>For bitwise access of PD_CFGo           |
| A20C0038 | <u>PD_CFGo CLR</u>     | 32    | <b>GPIO PD Control</b><br>For bitwise access of PD_CFGo           |
| A20C0040 | <u>PU_CFGo</u>         | 32    | <b>GPIO PU Control</b><br>Configures GPIO PU control              |
| A20C0044 | <u>PU_CFGo SET</u>     | 32    | <b>GPIO PU Control</b><br>For bitwise access of PU_CFGo           |
| A20C0048 | <u>PU_CFGo CLR</u>     | 32    | <b>GPIO PU Control</b><br>For bitwise access of PU_CFGo           |
| A20C0050 | <u>RDSEL_CFGo</u>      | 32    | <b>GPIO RDSEL Control</b><br>Configures GPIO RDSEL control        |
| A20C0054 | <u>RDSEL_CFGo SET</u>  | 32    | <b>GPIO RDSEL Control</b><br>For bitwise access of RDSEL_CFGo     |
| A20C0058 | <u>RDSEL_CFGo CLR</u>  | 32    | <b>GPIO RDSEL Control</b><br>For bitwise access of RDSEL_CFGo     |
| A20C0060 | <u>SMT_CFGo</u>        | 32    | <b>GPIO SMT Control</b><br>Configures GPIO SMT control            |
| A20C0064 | <u>SMT_CFGo SET</u>    | 32    | <b>GPIO SMT Control</b><br>For bitwise access of SMT_CFGo         |
| A20C0068 | <u>SMT_CFGo CLR</u>    | 32    | <b>GPIO SMT Control</b><br>For bitwise access of SMT_CFGo         |
| A20C0080 | <u>TDSEL_CFGoo</u>     | 32    | <b>GPIO TDSEL Control</b><br>Configures GPIO TDSEL control        |
| A20C0084 | <u>TDSEL_CFGoo SET</u> | 32    | <b>GPIO TDSEL Control</b><br>For bitwise access of TDSEL_CFGoo    |
| A20C0088 | <u>TDSEL_CFGoo CLR</u> | 32    | <b>GPIO TDSEL Control</b><br>For bitwise access of TDSEL_CFGoo    |
| A20C0090 | <u>TDSEL_CFGo1</u>     | 32    | <b>GPIO TDSEL Control</b><br>Configures GPIO TDSEL control        |
| A20C0094 | <u>TDSEL_CFGo1 SET</u> | 32    | <b>GPIO TDSEL Control</b><br>For bitwise access of TDSEL_CFGo1    |
| A20C0098 | <u>TDSEL_CFGo1 CLR</u> | 32    | <b>GPIO TDSEL Control</b><br>For bitwise access of TDSEL_CFGo1    |

Module name: IO\_CFG\_1 Base address: (+A20d0000h)

| Address  | Name                | Width | Register Function                                          |
|----------|---------------------|-------|------------------------------------------------------------|
| A20D0000 | <u>DRV_CFG1</u>     | 32    | <b>GPIO DRV Control</b><br>Configures GPIO driving control |
| A20D0004 | <u>DRV_CFG1 SET</u> | 32    | <b>GPIO DRV Control</b><br>For bitwise access of DRV_CFG1  |
| A20D0008 | <u>DRV_CFG1 CLR</u> | 32    | <b>GPIO DRV Control</b>                                    |

| Address  | Name                  | Width | Register Function                                                        |
|----------|-----------------------|-------|--------------------------------------------------------------------------|
|          |                       |       | For bitwise access of DRV_CFG1                                           |
| A20D0010 | <b>G_CFG1</b>         | 32    | <b>GPIO Analog input Control</b><br>Configures GPIO analog input control |
| A20D0014 | <b>G_CFG1_SET</b>     | 32    | <b>GPIO Analog input Control</b><br>For bitwise access of G_CFG1         |
| A20D0018 | <b>G_CFG1_CLR</b>     | 32    | <b>GPIO Analog input Control</b><br>For bitwise access of G_CFG1         |
| A20D0020 | <b>IES_CFG1</b>       | 32    | <b>GPIO IES Control</b><br>Configures GPIO input enabling control        |
| A20D0024 | <b>IES_CFG1_SET</b>   | 32    | <b>GPIO IES Control</b><br>For bitwise access of IES_CFG1                |
| A20D0028 | <b>IES_CFG1_CLR</b>   | 32    | <b>GPIO IES Control</b><br>For bitwise access of IES_CFG1                |
| A20D0030 | <b>PD_CFG1</b>        | 32    | <b>GPIO PD Control</b><br>Configures GPIO PD control                     |
| A20D0034 | <b>PD_CFG1_SET</b>    | 32    | <b>GPIO PD Control</b><br>For bitwise access of PD_CFG1                  |
| A20D0038 | <b>PD_CFG1_CLR</b>    | 32    | <b>GPIO PD Control</b><br>For bitwise access of PD_CFG1                  |
| A20D0040 | <b>PUPD_CFG1</b>      | 32    | <b>GPIO PUPD Control</b><br>Configures GPIO PUPD control                 |
| A20D0044 | <b>PUPD_CFG1_SET</b>  | 32    | <b>GPIO PUPD Control</b><br>For bitwise access of PUPD_CFG1              |
| A20D0048 | <b>PUPD_CFG1_CLR</b>  | 32    | <b>GPIO PUPD Control</b><br>For bitwise access of PUPD_CFG1              |
| A20D0050 | <b>PU_CFG1</b>        | 32    | <b>GPIO PU Control</b><br>Configures GPIO PU control                     |
| A20D0054 | <b>PU_CFG1_SET</b>    | 32    | <b>GPIO PU Control</b><br>For bitwise access of PU_CFG1                  |
| A20D0058 | <b>PU_CFG1_CLR</b>    | 32    | <b>GPIO PU Control</b><br>For bitwise access of PU_CFG1                  |
| A20D0060 | <b>Ro_CFG1</b>        | 32    | <b>GPIO Ro Control</b><br>Configures GPIO Ro control                     |
| A20D0064 | <b>Ro_CFG1_SET</b>    | 32    | <b>GPIO Ro Control</b><br>For bitwise access of Ro_CFG1                  |
| A20D0068 | <b>Ro_CFG1_CLR</b>    | 32    | <b>GPIO Ro Control</b><br>For bitwise access of Ro_CFG1                  |
| A20D0070 | <b>R1_CFG1</b>        | 32    | <b>GPIO R1 Control</b><br>Configures GPIO R1 control                     |
| A20D0074 | <b>R1_CFG1_SET</b>    | 32    | <b>GPIO R1 Control</b><br>For bitwise access of R1_CFG1                  |
| A20D0078 | <b>R1_CFG1_CLR</b>    | 32    | <b>GPIO R1 Control</b><br>For bitwise access of R1_CFG1                  |
| A20D0080 | <b>RDSEL_CFG1</b>     | 32    | <b>GPIO RDSEL Control</b><br>Configures GPIO RDSEL control               |
| A20D0084 | <b>RDSEL_CFG1_SET</b> | 32    | <b>GPIO RDSEL Control</b><br>For bitwise access of RDSEL_CFG1            |
| A20D0088 | <b>RDSEL_CFG1_CLR</b> | 32    | <b>GPIO RDSEL Control</b><br>For bitwise access of RDSEL_CFG1            |
| A20D0090 | <b>SMT_CFG1</b>       | 32    | <b>GPIO SMT Control</b><br>Configures GPIO SMT control                   |
| A20D0094 | <b>SMT_CFG1_SET</b>   | 32    | <b>GPIO SMT Control</b><br>For bitwise access of SMT_CFG1                |

| Address  | Name                   | Width | Register Function                                              |
|----------|------------------------|-------|----------------------------------------------------------------|
| A20D0098 | <u>SMT CFG1 CLR</u>    | 32    | <b>GPIO SMT Control</b><br>For bitwise access of SMT_CFG1      |
| A20D00B0 | <u>TDSEL CFG10</u>     | 32    | <b>GPIO TDSEL Control</b><br>Configures GPIO TDSEL control     |
| A20D00B4 | <u>TDSEL CFG10 SET</u> | 32    | <b>GPIO TDSEL Control</b><br>For bitwise access of TDSEL_CFG10 |
| A20D00B8 | <u>TDSEL CFG10 CLR</u> | 32    | <b>GPIO TDSEL Control</b><br>For bitwise access of TDSEL_CFG10 |

| <b>A20B0ooo GPIO DIRo</b> |                   |                   |                   |                   |                   |    |    |    |    |                    |                   |                  |                  |                  | <b>GPIO Direction Control</b> |                   |  |  |
|---------------------------|-------------------|-------------------|-------------------|-------------------|-------------------|----|----|----|----|--------------------|-------------------|------------------|------------------|------------------|-------------------------------|-------------------|--|--|
| Bit                       | 31                | 30                | 29                | 28                | 27                | 26 | 25 | 24 | 23 | 22                 | 21                | 20               | 19               | 18               | 17                            | 16                |  |  |
| <b>Name</b>               |                   |                   |                   |                   |                   |    |    |    |    | <b>GPIO 22_DIR</b> | <b>GPIO 21_DI</b> |                  |                  |                  | <b>GPIO 17_DI</b>             | <b>GPIO 16_DI</b> |  |  |
| <b>Type</b>               |                   |                   |                   |                   |                   |    |    |    |    | RW                 | RW                |                  |                  |                  | RW                            | RW                |  |  |
| <b>Reset</b>              |                   |                   |                   |                   |                   |    |    |    | 0  | 1                  | 0                 | 1                | 0                | 0                | 0                             | 0                 |  |  |
| <b>Bit</b>                | 15                | 14                | 13                | 12                | 11                | 10 | 9  | 8  | 7  | 6                  | 5                 | 4                | 3                | 2                | 1                             | 0                 |  |  |
| <b>Name</b>               | <b>GPIO 15_DI</b> | <b>GPIO 14_DI</b> | <b>GPIO 13_DI</b> | <b>GPIO 12_DI</b> | <b>GPIO 11_DI</b> |    |    |    |    | <b>GPIO 4_DI</b>   | <b>GPIO 3_DI</b>  | <b>GPIO 2_DI</b> | <b>GPIO 1_DI</b> | <b>GPIO 0_DI</b> |                               |                   |  |  |
| <b>Type</b>               | RW                | RW                | RW                | RW                | RW                |    |    |    |    | RW                 | RW                | RW               | RW               | RW               | RW                            | RW                |  |  |
| <b>Reset</b>              | 0                 | 0                 | 0                 | 0                 | 0                 | 0  | 0  | 0  | 0  | 0                  | 0                 | 1                | 0                | 0                | 0                             | 0                 |  |  |

| Bit(s) | Mnemonic      | Name       | Description                                                              |
|--------|---------------|------------|--------------------------------------------------------------------------|
| 22     | <b>GPIO22</b> | GPIO22_DIR | <b>GPIO22 direction control</b><br>0: GPIO as input<br>1: GPIO as output |
| 21     | <b>GPIO21</b> | GPIO21_DIR | <b>GPIO21 direction control</b><br>0: GPIO as input<br>1: GPIO as output |
| 17     | <b>GPIO17</b> | GPIO17_DIR | <b>GPIO17 direction control</b><br>0: GPIO as input<br>1: GPIO as output |
| 16     | <b>GPIO16</b> | GPIO16_DIR | <b>GPIO16 direction control</b><br>0: GPIO as input<br>1: GPIO as output |
| 15     | <b>GPIO15</b> | GPIO15_DIR | <b>GPIO15 direction control</b><br>0: GPIO as input<br>1: GPIO as output |
| 14     | <b>GPIO14</b> | GPIO14_DIR | <b>GPIO14 direction control</b><br>0: GPIO as input<br>1: GPIO as output |
| 13     | <b>GPIO13</b> | GPIO13_DIR | <b>GPIO13 direction control</b><br>0: GPIO as input<br>1: GPIO as output |
| 12     | <b>GPIO12</b> | GPIO12_DIR | <b>GPIO12 direction control</b><br>0: GPIO as input<br>1: GPIO as output |
| 11     | <b>GPIO11</b> | GPIO11_DIR | <b>GPIO11 direction control</b><br>0: GPIO as input<br>1: GPIO as output |
| 4      | <b>GPIO4</b>  | GPIO4_DIR  | <b>GPIO4 direction control</b><br>0: GPIO as input<br>1: GPIO as output  |
| 3      | <b>GPIO3</b>  | GPIO3_DIR  | <b>GPIO3 direction control</b>                                           |

| Bit(s) | Mnemonic     | Name      | Description                                                             |
|--------|--------------|-----------|-------------------------------------------------------------------------|
| 2      | <b>GPIO2</b> | GPIO2_DIR | o: GPIO as input<br>1: GPIO as output<br><b>GPIO2 direction control</b> |
| 1      | <b>GPIO1</b> | GPIO1_DIR | o: GPIO as input<br>1: GPIO as output<br><b>GPIO1 direction control</b> |
| 0      | <b>GPIOo</b> | GPIOo_DIR | o: GPIO as input<br>1: GPIO as output<br><b>GPIOo direction control</b> |

| <b>A20B0004 GPIO DIRo SET</b> |                  |                  |                  |                  |                  |    |    |    |    |                 |                  |                 |                 |                 | <b>GPIO Direction Control</b> |                  |  |  |
|-------------------------------|------------------|------------------|------------------|------------------|------------------|----|----|----|----|-----------------|------------------|-----------------|-----------------|-----------------|-------------------------------|------------------|--|--|
| Bit                           | 31               | 30               | 29               | 28               | 27               | 26 | 25 | 24 | 23 | 22              | 21               | 20              | 19              | 18              | 17                            | 16               |  |  |
| <b>Name</b>                   |                  |                  |                  |                  |                  |    |    |    |    | <b>GPIO22_D</b> | <b>GPIO21_DI</b> |                 |                 |                 | <b>GPIO17_DI</b>              | <b>GPIO16_DI</b> |  |  |
| <b>Type</b>                   |                  |                  |                  |                  |                  |    |    |    |    | WO              | WO               |                 |                 |                 | WO                            | WO               |  |  |
| <b>Reset</b>                  |                  |                  |                  |                  |                  |    |    |    |    | 0               | 0                |                 |                 |                 | 0                             | 0                |  |  |
| Bit                           | 15               | 14               | 13               | 12               | 11               | 10 | 9  | 8  | 7  | 6               | 5                | 4               | 3               | 2               | 1                             | 0                |  |  |
| <b>Name</b>                   | <b>GPIO15_DI</b> | <b>GPIO14_DI</b> | <b>GPIO13_DI</b> | <b>GPIO12_DI</b> | <b>GPIO11_DI</b> |    |    |    |    |                 |                  | <b>GPIO4_DI</b> | <b>GPIO3_DI</b> | <b>GPIO2_DI</b> | <b>GPIO1_DI</b>               | <b>GPIO0_DI</b>  |  |  |
| <b>Type</b>                   | WO               | WO               | WO               | WO               | WO               |    |    |    |    |                 |                  | WO              | WO              | WO              | WO                            | WO               |  |  |
| <b>Reset</b>                  | 0                | 0                | 0                | 0                | 0                |    |    |    |    |                 |                  | 0               | 0               | 0               | 0                             | 0                |  |  |

| Bit(s) | Mnemonic      | Name           | Description                                                                |
|--------|---------------|----------------|----------------------------------------------------------------------------|
| 22     | <b>GPIO22</b> | GPIO22_DIR_SET | <b>Bitwise SET operation of GPIO22 direction</b><br>0: Keep<br>1: SET bits |
| 21     | <b>GPIO21</b> | GPIO21_DIR_SET | <b>Bitwise SET operation of GPIO21 direction</b><br>0: Keep<br>1: SET bits |
| 17     | <b>GPIO17</b> | GPIO17_DIR_SET | <b>Bitwise SET operation of GPIO17 direction</b><br>0: Keep<br>1: SET bits |
| 16     | <b>GPIO16</b> | GPIO16_DIR_SET | <b>Bitwise SET operation of GPIO16 direction</b><br>0: Keep<br>1: SET bits |
| 15     | <b>GPIO15</b> | GPIO15_DIR_SET | <b>Bitwise SET operation of GPIO15 direction</b><br>0: Keep<br>1: SET bits |
| 14     | <b>GPIO14</b> | GPIO14_DIR_SET | <b>Bitwise SET operation of GPIO14 direction</b><br>0: Keep<br>1: SET bits |
| 13     | <b>GPIO13</b> | GPIO13_DIR_SET | <b>Bitwise SET operation of GPIO13 direction</b><br>0: Keep<br>1: SET bits |
| 12     | <b>GPIO12</b> | GPIO12_DIR_SET | <b>Bitwise SET operation of GPIO12 direction</b><br>0: Keep<br>1: SET bits |
| 11     | <b>GPIO11</b> | GPIO11_DIR_SET | <b>Bitwise SET operation of GPIO11 direction</b>                           |

| Bit(s) | Mnemonic     | Name          | Description                                                               |
|--------|--------------|---------------|---------------------------------------------------------------------------|
| 4      | <b>GPIO4</b> | GPIO4_DIR_SET | o: Keep<br>1: SET bits<br><b>Bitwise SET operation of GPIO4 direction</b> |
| 3      | <b>GPIO3</b> | GPIO3_DIR_SET | o: Keep<br>1: SET bits<br><b>Bitwise SET operation of GPIO3 direction</b> |
| 2      | <b>GPIO2</b> | GPIO2_DIR_SET | o: Keep<br>1: SET bits<br><b>Bitwise SET operation of GPIO2 direction</b> |
| 1      | <b>GPIO1</b> | GPIO1_DIR_SET | o: Keep<br>1: SET bits<br><b>Bitwise SET operation of GPIO1 direction</b> |
| 0      | <b>GPIOo</b> | GPIOo_DIR_SET | o: Keep<br>1: SET bits<br><b>Bitwise SET operation of GPIOo direction</b> |

| <b>A20B0008 GPIO_DIRo_CLR</b> |                            |                            |                            |                            |                            |    |    |    |    |                            |                            |                           |                           |                           | <b>GPIO Direction Control</b> |                            |  |  |
|-------------------------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|----|----|----|----|----------------------------|----------------------------|---------------------------|---------------------------|---------------------------|-------------------------------|----------------------------|--|--|
| Bit                           | 31                         | 30                         | 29                         | 28                         | 27                         | 26 | 25 | 24 | 23 | 22                         | 21                         | 20                        | 19                        | 18                        | 17                            | 16                         |  |  |
| <b>Name</b>                   |                            |                            |                            |                            |                            |    |    |    |    | GPIO<br>22_D<br>IR_C<br>LR | GPIO<br>21_DI<br>R_CL<br>R |                           |                           |                           | GPIO<br>17_DI<br>R_CL<br>R    | GPIO<br>16_DI<br>R_CL<br>R |  |  |
| <b>Type</b>                   |                            |                            |                            |                            |                            |    |    |    |    | WO                         | WO                         |                           |                           |                           | WO                            | WO                         |  |  |
| <b>Reset</b>                  |                            |                            |                            |                            |                            |    |    |    |    | 0                          | 0                          |                           |                           |                           | 0                             | 0                          |  |  |
| Bit                           | 15                         | 14                         | 13                         | 12                         | 11                         | 10 | 9  | 8  | 7  | 6                          | 5                          | 4                         | 3                         | 2                         | 1                             | 0                          |  |  |
| <b>Name</b>                   | GPIO<br>15_DI<br>R_CL<br>R | GPIO<br>14_DI<br>R_CL<br>R | GPIO<br>13_DI<br>R_CL<br>R | GPIO<br>12_DI<br>R_CL<br>R | GPIO<br>11_DI<br>R_CL<br>R |    |    |    |    |                            |                            | GPIO<br>4_DI<br>R_CL<br>R | GPIO<br>3_DI<br>R_CL<br>R | GPIO<br>2_DI<br>R_CL<br>R | GPIO<br>1_DI<br>R_CL<br>R     | GPIO<br>0_DI<br>R_CL<br>R  |  |  |
| <b>Type</b>                   | WO                         | WO                         | WO                         | WO                         | WO                         |    |    |    |    |                            |                            | WO                        | WO                        | WO                        | WO                            | WO                         |  |  |
| <b>Reset</b>                  | 0                          | 0                          | 0                          | 0                          | 0                          |    |    |    |    |                            |                            | 0                         | 0                         | 0                         | 0                             | 0                          |  |  |

| Bit(s) | Mnemonic      | Name           | Description                                                                    |
|--------|---------------|----------------|--------------------------------------------------------------------------------|
| 22     | <b>GPIO22</b> | GPIO22_DIR_CLR | <b>Bitwise CLEAR operation of GPIO22 direction</b><br>o: Keep<br>1: Clear bits |
| 21     | <b>GPIO21</b> | GPIO21_DIR_CLR | <b>Bitwise CLEAR operation of GPIO21 direction</b><br>o: Keep<br>1: Clear bits |
| 17     | <b>GPIO17</b> | GPIO17_DIR_CLR | <b>Bitwise CLEAR operation of GPIO17 direction</b><br>o: Keep<br>1: Clear bits |
| 16     | <b>GPIO16</b> | GPIO16_DIR_CLR | <b>Bitwise CLEAR operation of GPIO16 direction</b><br>o: Keep<br>1: Clear bits |
| 15     | <b>GPIO15</b> | GPIO15_DIR_CLR | <b>Bitwise CLEAR operation of GPIO15 direction</b><br>o: Keep<br>1: Clear bits |
| 14     | <b>GPIO14</b> | GPIO14_DIR_CLR | <b>Bitwise CLEAR operation of GPIO14 direction</b><br>o: Keep<br>1: Clear bits |
| 13     | <b>GPIO13</b> | GPIO13_DIR_CLR | <b>Bitwise CLEAR operation of GPIO13 direction</b><br>o: Keep                  |

| Bit(s) | Mnemonic      | Name           | Description                                                                    |
|--------|---------------|----------------|--------------------------------------------------------------------------------|
| 12     | <b>GPIO12</b> | GPIO12_DIR_CLR | 1: Clear bits<br><b>Bitwise CLEAR operation of GPIO12 direction</b><br>0: Keep |
| 11     | <b>GPIO11</b> | GPIO11_DIR_CLR | 1: Clear bits<br><b>Bitwise CLEAR operation of GPIO11 direction</b><br>0: Keep |
| 4      | <b>GPIO4</b>  | GPIO4_DIR_CLR  | 1: Clear bits<br><b>Bitwise CLEAR operation of GPIO4 direction</b><br>0: Keep  |
| 3      | <b>GPIO3</b>  | GPIO3_DIR_CLR  | 1: Clear bits<br><b>Bitwise CLEAR operation of GPIO3 direction</b><br>0: Keep  |
| 2      | <b>GPIO2</b>  | GPIO2_DIR_CLR  | 1: Clear bits<br><b>Bitwise CLEAR operation of GPIO2 direction</b><br>0: Keep  |
| 1      | <b>GPIO1</b>  | GPIO1_DIR_CLR  | 1: Clear bits<br><b>Bitwise CLEAR operation of GPIO1 direction</b><br>0: Keep  |
| 0      | <b>GPIOo</b>  | GPIOo_DIR_CLR  | 1: Clear bits<br><b>Bitwise CLEAR operation of GPIOo direction</b><br>0: Keep  |

| A20B0020 GPIO_DOUTo |                    |                    |                    |                    |                    |    |    |    |    |                    |                    |                   |                   |                   | GPIO Output Data Control |                    |  |  |
|---------------------|--------------------|--------------------|--------------------|--------------------|--------------------|----|----|----|----|--------------------|--------------------|-------------------|-------------------|-------------------|--------------------------|--------------------|--|--|
| Bit                 | 31                 | 30                 | 29                 | 28                 | 27                 | 26 | 25 | 24 | 23 | 22                 | 21                 | 20                | 19                | 18                | 17                       | 16                 |  |  |
| Name                |                    |                    |                    |                    |                    |    |    |    |    | GPIO<br>22_O<br>UT | GPIO<br>21_O<br>UT |                   |                   |                   | GPIO<br>17_O<br>UT       | GPIO<br>16_O<br>UT |  |  |
| Type                |                    |                    |                    |                    |                    |    |    |    |    | RW                 | RW                 |                   |                   |                   | RW                       | RW                 |  |  |
| Reset               |                    |                    |                    |                    |                    |    |    |    | 0  | 0                  | 1                  | 0                 | 0                 | 0                 | 0                        | 0                  |  |  |
| Bit                 | 15                 | 14                 | 13                 | 12                 | 11                 | 10 | 9  | 8  | 7  | 6                  | 5                  | 4                 | 3                 | 2                 | 1                        | 0                  |  |  |
| Name                | GPIO<br>15_O<br>UT | GPIO<br>14_O<br>UT | GPIO<br>13_O<br>UT | GPIO<br>12_O<br>UT | GPIO<br>11_O<br>UT |    |    |    |    |                    |                    | GPIO<br>4_OU<br>T | GPIO<br>3_OU<br>T | GPIO<br>2_OU<br>T | GPIO<br>1_OU<br>T        | GPIO<br>0_OU<br>T  |  |  |
| Type                | RW                 | RW                 | RW                 | RW                 | RW                 |    |    |    |    |                    |                    | RW                | RW                | RW                | RW                       | RW                 |  |  |
| Reset               | 0                  | 0                  | 0                  | 0                  | 0                  | 0  | 0  | 0  | 0  | 0                  | 0                  | 0                 | 0                 | 0                 | 0                        | 0                  |  |  |

| Bit(s) | Mnemonic      | Name       | Description                                                               |
|--------|---------------|------------|---------------------------------------------------------------------------|
| 22     | <b>GPIO22</b> | GPIO22_OUT | <b>GPIO22 data output value</b><br>0: GPIO output LO<br>1: GPIO output HI |
| 21     | <b>GPIO21</b> | GPIO21_OUT | <b>GPIO21 data output value</b><br>0: GPIO output LO<br>1: GPIO output HI |
| 17     | <b>GPIO17</b> | GPIO17_OUT | <b>GPIO17 data output value</b><br>0: GPIO output LO<br>1: GPIO output HI |
| 16     | <b>GPIO16</b> | GPIO16_OUT | <b>GPIO16 data output value</b><br>0: GPIO output LO<br>1: GPIO output HI |
| 15     | <b>GPIO15</b> | GPIO15_OUT | <b>GPIO15 data output value</b><br>0: GPIO output LO<br>1: GPIO output HI |
| 14     | <b>GPIO14</b> | GPIO14_OUT | <b>GPIO14 data output value</b>                                           |

| Bit(s) | Mnemonic      | Name       | Description                                                               |
|--------|---------------|------------|---------------------------------------------------------------------------|
| 13     | <b>GPIO13</b> | GPIO13_OUT | o: GPIO output LO<br>1: GPIO output HI<br><b>GPIO13 data output value</b> |
| 12     | <b>GPIO12</b> | GPIO12_OUT | o: GPIO output LO<br>1: GPIO output HI<br><b>GPIO12 data output value</b> |
| 11     | <b>GPIO11</b> | GPIO11_OUT | o: GPIO output LO<br>1: GPIO output HI<br><b>GPIO11 data output value</b> |
| 4      | <b>GPIO4</b>  | GPIO4_OUT  | o: GPIO output LO<br>1: GPIO output HI<br><b>GPIO4 data output value</b>  |
| 3      | <b>GPIO3</b>  | GPIO3_OUT  | o: GPIO output LO<br>1: GPIO output HI<br><b>GPIO3 data output value</b>  |
| 2      | <b>GPIO2</b>  | GPIO2_OUT  | o: GPIO output LO<br>1: GPIO output HI<br><b>GPIO2 data output value</b>  |
| 1      | <b>GPIO1</b>  | GPIO1_OUT  | o: GPIO output LO<br>1: GPIO output HI<br><b>GPIO1 data output value</b>  |
| 0      | <b>GPIOo</b>  | GPIOo_OUT  | o: GPIO output LO<br>1: GPIO output HI<br><b>GPIOo data output value</b>  |

| A20B0024 GPIO_DOUTo_SET |                            |                            |                            |                            |                            |    |    |    |    |                            |                            |                           |                           |                           | GPIO Output Data Control   |                            |  |  |  | oooooooooooo |  |  |  |  |
|-------------------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|----|----|----|----|----------------------------|----------------------------|---------------------------|---------------------------|---------------------------|----------------------------|----------------------------|--|--|--|--------------|--|--|--|--|
| Bit                     | 31                         | 30                         | 29                         | 28                         | 27                         | 26 | 25 | 24 | 23 | 22                         | 21                         | 20                        | 19                        | 18                        | 17                         | 16                         |  |  |  |              |  |  |  |  |
| Name                    |                            |                            |                            |                            |                            |    |    |    |    | GPIO<br>22_O<br>UT_S<br>ET | GPIO<br>21_O<br>UT_S<br>ET |                           |                           |                           | GPIO<br>17_O<br>UT_S<br>ET | GPIO<br>16_O<br>UT_S<br>ET |  |  |  |              |  |  |  |  |
| Type                    |                            |                            |                            |                            |                            |    |    |    |    | WO                         | WO                         |                           |                           |                           | WO                         | WO                         |  |  |  |              |  |  |  |  |
| Reset                   |                            |                            |                            |                            |                            |    |    |    |    | 0                          | 0                          |                           |                           |                           | 0                          | 0                          |  |  |  |              |  |  |  |  |
| Bit                     | 15                         | 14                         | 13                         | 12                         | 11                         | 10 | 9  | 8  | 7  | 6                          | 5                          | 4                         | 3                         | 2                         | 1                          | 0                          |  |  |  |              |  |  |  |  |
| Name                    | GPIO<br>15_O<br>UT_S<br>ET | GPIO<br>14_O<br>UT_S<br>ET | GPIO<br>13_O<br>UT_S<br>ET | GPIO<br>12_O<br>UT_S<br>ET | GPIO<br>11_O<br>UT_S<br>ET |    |    |    |    |                            |                            | GPIO<br>4_OU<br>T_SE<br>T | GPIO<br>3_OU<br>T_SE<br>T | GPIO<br>2_OU<br>T_SE<br>T | GPIO<br>1_OU<br>T_SE<br>T  | GPIO<br>0_OU<br>T_SE<br>T  |  |  |  |              |  |  |  |  |
| Type                    | WO                         | WO                         | WO                         | WO                         | WO                         |    |    |    |    |                            |                            | WO                        | WO                        | WO                        | WO                         | WO                         |  |  |  |              |  |  |  |  |
| Reset                   | 0                          | 0                          | 0                          | 0                          | 0                          |    |    |    |    |                            |                            | 0                         | 0                         | 0                         | 0                          | 0                          |  |  |  |              |  |  |  |  |

| Bit(s) | Mnemonic      | Name           | Description                                                                        |
|--------|---------------|----------------|------------------------------------------------------------------------------------|
| 22     | <b>GPIO22</b> | GPIO22_OUT_SET | <b>Bitwise SET operation of GPIO22 data output value</b><br>0: Keep<br>1: SET bits |
| 21     | <b>GPIO21</b> | GPIO21_OUT_SET | <b>Bitwise SET operation of GPIO21 data output value</b><br>0: Keep<br>1: SET bits |
| 17     | <b>GPIO17</b> | GPIO17_OUT_SET | <b>Bitwise SET operation of GPIO17 data output value</b><br>0: Keep                |

| Bit(s) | Mnemonic      | Name           | Description                                                                        |
|--------|---------------|----------------|------------------------------------------------------------------------------------|
| 16     | <b>GPIO16</b> | GPIO16_OUT_SET | 1: SET bits<br><b>Bitwise SET operation of GPIO16 data output value</b><br>0: Keep |
| 15     | <b>GPIO15</b> | GPIO15_OUT_SET | 1: SET bits<br><b>Bitwise SET operation of GPIO15 data output value</b><br>0: Keep |
| 14     | <b>GPIO14</b> | GPIO14_OUT_SET | 1: SET bits<br><b>Bitwise SET operation of GPIO14 data output value</b><br>0: Keep |
| 13     | <b>GPIO13</b> | GPIO13_OUT_SET | 1: SET bits<br><b>Bitwise SET operation of GPIO13 data output value</b><br>0: Keep |
| 12     | <b>GPIO12</b> | GPIO12_OUT_SET | 1: SET bits<br><b>Bitwise SET operation of GPIO12 data output value</b><br>0: Keep |
| 11     | <b>GPIO11</b> | GPIO11_OUT_SET | 1: SET bits<br><b>Bitwise SET operation of GPIO11 data output value</b><br>0: Keep |
| 4      | <b>GPIO4</b>  | GPIO4_OUT_SET  | 1: SET bits<br><b>Bitwise SET operation of GPIO4 data output value</b><br>0: Keep  |
| 3      | <b>GPIO3</b>  | GPIO3_OUT_SET  | 1: SET bits<br><b>Bitwise SET operation of GPIO3 data output value</b><br>0: Keep  |
| 2      | <b>GPIO2</b>  | GPIO2_OUT_SET  | 1: SET bits<br><b>Bitwise SET operation of GPIO2 data output value</b><br>0: Keep  |
| 1      | <b>GPIO1</b>  | GPIO1_OUT_SET  | 1: SET bits<br><b>Bitwise SET operation of GPIO1 data output value</b><br>0: Keep  |
| 0      | <b>GPIOo</b>  | GPIOo_OUT_SET  | 1: SET bits<br><b>Bitwise SET operation of GPIOo data output value</b><br>0: Keep  |

| A20B0028 GPIO_DOUTo_CLR      GPIO Output Data Control |                 |                 |                 |                 |                 |    |    |    |    |                 |                 |                 |                 |                 | oooooooooooo    |                 |
|-------------------------------------------------------|-----------------|-----------------|-----------------|-----------------|-----------------|----|----|----|----|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|
| Bit                                                   | 31              | 30              | 29              | 28              | 27              | 26 | 25 | 24 | 23 | 22              | 21              | 20              | 19              | 18              | 17              | 16              |
| <b>Name</b>                                           |                 |                 |                 |                 |                 |    |    |    |    | <b>GPIO22_O</b> | <b>GPIO21_O</b> |                 |                 |                 | <b>GPIO17_O</b> | <b>GPIO16_O</b> |
| <b>Type</b>                                           |                 |                 |                 |                 |                 |    |    |    |    | UT_C            | UT_C            |                 |                 |                 | UT_C            | UT_C            |
| <b>Reset</b>                                          |                 |                 |                 |                 |                 |    |    |    |    | LR              | LR              |                 |                 |                 | LR              | LR              |
| <b>Bit</b>                                            | 15              | 14              | 13              | 12              | 11              | 10 | 9  | 8  | 7  | 6               | 5               | 4               | 3               | 2               | 1               | 0               |
| <b>Name</b>                                           | <b>GPIO15_O</b> | <b>GPIO14_O</b> | <b>GPIO13_O</b> | <b>GPIO12_O</b> | <b>GPIO11_O</b> |    |    |    |    |                 |                 | <b>GPIO4_OU</b> | <b>GPIO3_OU</b> | <b>GPIO2_OU</b> | <b>GPIO1_OU</b> | <b>GPIO0_OU</b> |

|       | UT_C<br>LR | UT_C<br>LR | UT_C<br>LR | UT_C<br>LR | UT_C<br>LR |  |  |  |  |    | T_CL<br>R | T_CL<br>R | T_CL<br>R | T_CL<br>R | T_CL<br>R |
|-------|------------|------------|------------|------------|------------|--|--|--|--|----|-----------|-----------|-----------|-----------|-----------|
| Type  | WO         | WO         | WO         | WO         | WO         |  |  |  |  | WO | WO        | WO        | WO        | WO        |           |
| Reset | o          | o          | o          | o          | o          |  |  |  |  | o  | o         | o         | o         | o         |           |

| Bit(s) | Mnemonic      | Name           | Description                                                                                    |
|--------|---------------|----------------|------------------------------------------------------------------------------------------------|
| 22     | <b>GPIO22</b> | GPIO22_OUT_CLR | <b>Bitwise CLEAR operation of GPIO22 data output value</b><br><br>o: Keep<br><br>1: Clear bits |
| 21     | <b>GPIO21</b> | GPIO21_OUT_CLR | <b>Bitwise CLEAR operation of GPIO21 data output value</b><br><br>o: Keep<br><br>1: Clear bits |
| 17     | <b>GPIO17</b> | GPIO17_OUT_CLR | <b>Bitwise CLEAR operation of GPIO17 data output value</b><br><br>o: Keep<br><br>1: Clear bits |
| 16     | <b>GPIO16</b> | GPIO16_OUT_CLR | <b>Bitwise CLEAR operation of GPIO16 data output value</b><br><br>o: Keep<br><br>1: Clear bits |
| 15     | <b>GPIO15</b> | GPIO15_OUT_CLR | <b>Bitwise CLEAR operation of GPIO15 data output value</b><br><br>o: Keep<br><br>1: Clear bits |
| 14     | <b>GPIO14</b> | GPIO14_OUT_CLR | <b>Bitwise CLEAR operation of GPIO14 data output value</b><br><br>o: Keep<br><br>1: Clear bits |
| 13     | <b>GPIO13</b> | GPIO13_OUT_CLR | <b>Bitwise CLEAR operation of GPIO13 data output value</b><br><br>o: Keep<br><br>1: Clear bits |
| 12     | <b>GPIO12</b> | GPIO12_OUT_CLR | <b>Bitwise CLEAR operation of GPIO12 data output value</b><br><br>o: Keep<br><br>1: Clear bits |
| 11     | <b>GPIO11</b> | GPIO11_OUT_CLR | <b>Bitwise CLEAR operation of GPIO11 data output value</b>                                     |

---

|   |              |               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|---|--------------|---------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
|   |              |               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 4 | <b>GPIO4</b> |               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |              | GPIO4_OUT_CLR |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |              |               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 3 | <b>GPIO3</b> |               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |              | GPIO3_OUT_CLR |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |              |               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 2 | <b>GPIO2</b> |               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |              | GPIO2_OUT_CLR |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |              |               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 1 | <b>GPIO1</b> |               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |              | GPIO1_OUT_CLR |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |              |               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| 0 | <b>GPIOo</b> |               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |              | GPIOo_OUT_CLR |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|   |              |               |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

**A20B0030 GPIO DINo**

**GPIO Input Data Value**

**oooooooooooo**

| Bit   | 31                 | 30                 | 29                 | 28                 | 27                 | 26 | 25 | 24 | 23 | 22                 | 21                 | 20                | 19                | 18                | 17                 | 16                 |
|-------|--------------------|--------------------|--------------------|--------------------|--------------------|----|----|----|----|--------------------|--------------------|-------------------|-------------------|-------------------|--------------------|--------------------|
| Name  |                    |                    |                    |                    |                    |    |    |    |    | GPIO<br>22_D<br>IN | GPIO<br>21_DI<br>N |                   |                   |                   | GPIO<br>17_DI<br>N | GPIO<br>16_DI<br>N |
| Type  |                    |                    |                    |                    |                    |    |    |    |    | RO                 | RO                 |                   |                   |                   | RO                 | RO                 |
| Reset |                    |                    |                    |                    |                    |    |    |    |    | o                  | o                  |                   |                   |                   | o                  | o                  |
| Bit   | 15                 | 14                 | 13                 | 12                 | 11                 | 10 | 9  | 8  | 7  | 6                  | 5                  | 4                 | 3                 | 2                 | 1                  | 0                  |
| Name  | GPIO<br>15_DI<br>N | GPIO<br>14_DI<br>N | GPIO<br>13_DI<br>N | GPIO<br>12_DI<br>N | GPIO<br>11_DI<br>N |    |    |    |    |                    |                    | GPIO<br>4_DI<br>N | GPIO<br>3_DI<br>N | GPIO<br>2_DI<br>N | GPIO<br>1_DI<br>N  | GPIO<br>0_DI<br>N  |
| Type  | RO                 | RO                 | RO                 | RO                 | RO                 |    |    |    |    |                    |                    | RO                | RO                | RO                | RO                 | RO                 |
| Reset | o                  | o                  | o                  | o                  | o                  |    |    |    |    |                    |                    | o                 | o                 | o                 | o                  | o                  |

| Bit(s) | Mnemonic      | Name       | Description                    |
|--------|---------------|------------|--------------------------------|
| 22     | <b>GPIO22</b> | GPIO22_DIN | <b>GPIO22</b> data input value |
| 21     | <b>GPIO21</b> | GPIO21_DIN | <b>GPIO21</b> data input value |
| 17     | <b>GPIO17</b> | GPIO17_DIN | <b>GPIO17</b> data input value |
| 16     | <b>GPIO16</b> | GPIO16_DIN | <b>GPIO16</b> data input value |
| 15     | <b>GPIO15</b> | GPIO15_DIN | <b>GPIO15</b> data input value |

| Bit(s) | Mnemonic | Name       | Description             |
|--------|----------|------------|-------------------------|
| 14     | GPIO14   | GPIO14_DIN | GPIO14 data input value |
| 13     | GPIO13   | GPIO13_DIN | GPIO13 data input value |
| 12     | GPIO12   | GPIO12_DIN | GPIO12 data input value |
| 11     | GPIO11   | GPIO11_DIN | GPIO11 data input value |
| 4      | GPIO4    | GPIO4_DIN  | GPIO4 data input value  |
| 3      | GPIO3    | GPIO3_DIN  | GPIO3 data input value  |
| 2      | GPIO2    | GPIO2_DIN  | GPIO2 data input value  |
| 1      | GPIO1    | GPIO1_DIN  | GPIO1 data input value  |
| 0      | GPIOo    | GPIOo_DIN  | GPIOo data input value  |

| A20B0040 GPIO MODEo |            |    |    |    |            |    |    |    |            |    |    |    |            |    |    | GPIO Mode Control |          |  |  |  |
|---------------------|------------|----|----|----|------------|----|----|----|------------|----|----|----|------------|----|----|-------------------|----------|--|--|--|
| Bit                 | 31         | 30 | 29 | 28 | 27         | 26 | 25 | 24 | 23         | 22 | 21 | 20 | 19         | 18 | 17 | 16                | 00066666 |  |  |  |
| Name                |            |    |    |    |            |    |    |    |            |    |    |    | GPIO4_MODE |    |    |                   |          |  |  |  |
| Type                |            |    |    |    |            |    |    |    |            |    |    |    | RW         |    |    |                   |          |  |  |  |
| Reset               | 0          | 0  | 0  | 0  | 0          | 0  | 0  | 0  | 0          | 0  | 0  | 0  | 0          | 1  | 1  | 0                 |          |  |  |  |
| Bit                 | 15         | 14 | 13 | 12 | 11         | 10 | 9  | 8  | 7          | 6  | 5  | 4  | 3          | 2  | 1  | 0                 |          |  |  |  |
| Name                | GPIO3_MODE |    |    |    | GPIO2_MODE |    |    |    | GPIO1_MODE |    |    |    | GPIOo_MODE |    |    |                   |          |  |  |  |
| Type                | RW         |    |    |                   |          |  |  |  |
| Reset               | 0          | 1  | 1  | 0  | 0          | 1  | 1  | 0  | 0          | 1  | 1  | 0  | 0          | 1  | 1  | 0                 |          |  |  |  |

| Bit(s) | Mnemonic | Name       | Description                                                                                                                                                                                                           |
|--------|----------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 19:16  |          | GPIO4_MODE | <b>Aux. mode of GPIO_4</b><br>0:GPIO4(IO)<br>1:SPISLV_A_SIO2(IO)<br>2:SPIMST_A_SIO2(IO)<br>3:EINT4(I)<br>4:Reserved<br>5:I2S_MCLK(O)<br>6:JTDO(O)<br>7:Reserved<br>8:Reserved<br>9:WIFI_ANT_SEL3(O)<br>10:I2S_MCLK(O) |
| 15:12  |          | GPIO3_MODE | <b>Aux. mode of GPIO_3</b><br>0:GPIO3(IO)<br>1:EINT3(I)<br>2:Reserved<br>3:UTXD1(O)<br>4:PWM1(O)<br>5:I2S_CK(IO)<br>6:JTRST_B(I)<br>7:Reserved<br>8:Reserved<br>9:WIFI_ANT_SEL2(O)<br>10:I2S_CK(O)                    |
| 11:8   |          | GPIO2_MODE | <b>Aux. mode of GPIO_2</b><br>0:GPIO2(IO)<br>1:EINT2(I)<br>2:Reserved<br>3:URXD1(I)<br>4:PWMO(O)                                                                                                                      |

| Bit(s) | Mnemonic | Name       | Description                                                                                                                                                                                                                      |
|--------|----------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:4    |          | GPIO1_MODE | <p><b>Aux. mode of GPIO_1</b></p> <p>5:I2S_WS(IO)<br/> 6:JTCK(I)<br/> 7:CLKO(O)<br/> 8:Reserved<br/> 9:BT_PRIo(IO)<br/> 10:WIFI_ANT_SEL4(O)</p>                                                                                  |
| 3:0    |          | GPIOo_MODE | <p><b>Aux. mode of GPIO_o</b></p> <p>0:GPIO1(IO)<br/> 1:EINT1(I)<br/> 2:Reserved<br/> 3:U1CTS(I)<br/> 4:SDA1(IO)<br/> 5:I2S_TX(O)<br/> 6:JTMS(IO)<br/> 7:Reserved<br/> 8:WIFI_ANT_SEL1(O)<br/> 9:BT_PRI3(IO)<br/> 10:PWM1(O)</p> |

| A20B0044 GPIO MODE1 |             |    |    | GPIO Mode Control |             |    |    |    |             |    |    |    |             |    |    | 00000000 |  |  |  |
|---------------------|-------------|----|----|-------------------|-------------|----|----|----|-------------|----|----|----|-------------|----|----|----------|--|--|--|
| Bit                 | 31          | 30 | 29 | 28                | 27          | 26 | 25 | 24 | 23          | 22 | 21 | 20 | 19          | 18 | 17 | 16       |  |  |  |
| Name                | GPIO15_MODE |    |    |                   | GPIO14_MODE |    |    |    | GPIO13_MODE |    |    |    | GPIO12_MODE |    |    |          |  |  |  |
| Type                | RW          |    |    |                   | RW          |    |    |    | RW          |    |    |    | RW          |    |    |          |  |  |  |
| Reset               | 0           | 0  | 0  | 0                 | 0           | 0  | 0  | 0  | 0           | 0  | 0  | 0  | 0           | 0  | 0  | 0        |  |  |  |
| Bit                 | 15          | 14 | 13 | 12                | 11          | 10 | 9  | 8  | 7           | 6  | 5  | 4  | 3           | 2  | 1  | 0        |  |  |  |
| Name                | GPIO11_MODE |    |    |                   |             |    |    |    |             |    |    |    |             |    |    |          |  |  |  |
| Type                | RW          |    |    |                   |             |    |    |    |             |    |    |    |             |    |    |          |  |  |  |
| Reset               | 0           | 0  | 0  | 0                 | 0           | 0  | 0  | 0  | 0           | 0  | 0  | 0  | 0           | 0  | 0  | 0        |  |  |  |

| Bit(s) | Mnemonic | Name        | Description                                                                                                                                                                                                                             |
|--------|----------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:28  |          | GPIO15_MODE | <p><b>Aux. mode of GPIO_15</b></p> <p>0:GPIO15(IO)<br/> 1:SPISLV_B_SIOo(IO)<br/> 2:SPIMST_B_SIOo(IO)<br/> 3:TDM_TX(O)<br/> 4:MA_MCo_DA2(IO)<br/> 5:SLV_MCo_DA2(IO)<br/> 6:SCL1(IO)<br/> 7:Reserved<br/> 8:EINT15(I)<br/> 9:Reserved</p> |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b> | <b>Description</b>                                                                                                                                                                                                                |
|---------------|-----------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|               |                 |             | 1o:PWM3(O)                                                                                                                                                                                                                        |
| 27:24         |                 | GPIO14_MODE | <b>Aux. mode of GPIO_14</b><br>0:GPIO14(IO)<br>1:SPISLV_B_SIO1(IO)<br>2:SPIMST_B_SIO1(IO)<br>3:TDM_RX(I)<br>4:MA_MCo_DA1(IO)<br>5:SLV_MCo_DA1(IO)<br>6:PWM4(O)<br>7:Reserved<br>8:EINT14(I)<br>9:Reserved<br>10:CLKO4(O)          |
| 23:20         |                 | GPIO13_MODE | <b>Aux. mode of GPIO_13</b><br>0:GPIO13(IO)<br>1:SPISLV_B_SIO2(IO)<br>2:SPIMST_B_SIO2(IO)<br>3:U2RTS(O)<br>4:MA_MCo_DAO(IO)<br>5:SLV_MCo_DAO(IO)<br>6:CLKO4(O)<br>7:Reserved<br>8:EINT13(I)<br>9:Reserved<br>10:I2S_WS(IO)        |
| 19:16         |                 | GPIO12_MODE | <b>Aux. mode of GPIO_12</b><br>0:GPIO12(IO)<br>1:SPISLV_B_SIO3(IO)<br>2:SPIMST_B_SIO3(IO)<br>3:UTXD2(O)<br>4:MA_MCo_CMO(IO)<br>5:SLV_MCo_CMO(IO)<br>6:EINT12(I)<br>7:Reserved<br>8:Reserved<br>9:WIFI_ANT_SEL1(O)<br>10:I2S_TX(O) |
| 15:12         |                 | GPIO11_MODE | <b>Aux. mode of GPIO_11</b><br>0:GPIO11(IO)<br>1:EINT11(I)<br>2:PWM3(O)<br>3:URXD2(I)<br>4:MA_MCo_CK(IO)<br>5:SLV_MCo_CK(IO)<br>6:CLKO2(O)<br>7:Reserved<br>8:Reserved<br>9:WIFI_ANT_SELo(O)<br>10:I2S_RX(I)                      |

**A2oBoo48    GPIO\_MODE2****GPIO Mode Control****00011600**

|              |                    |    |    |    |                    |    |    |    |    |    |    |    |    |    |    |    |
|--------------|--------------------|----|----|----|--------------------|----|----|----|----|----|----|----|----|----|----|----|
| <b>Bit</b>   | 31                 | 30 | 29 | 28 | 27                 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b>  | <b>GPIO22_MODE</b> |    |    |    | <b>GPIO21_MODE</b> |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW                 |    |    |    | RW                 |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> |                    |    |    |    | 0                  | 0  | 0  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 1  |
| <b>Bit</b>   | 15                 | 14 | 13 | 12 | 11                 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | <b>GPIO17_MODE</b> |    |    |    | <b>GPIO16_MODE</b> |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW                 |    |    |    | RW                 |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                  | 0  | 0  | 1  | 0                  | 1  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b>        | <b>Description</b>                                                                                                                                                                                              |
|---------------|-----------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27:24         |                 | <b>GPIO22_MODE</b> | <b>Aux. mode of GPIO_22</b><br>0:GPIO22(IO)<br>1:UTXDo(O)<br>2:EINT20(I)<br>3:Reserved<br>4:Reserved<br>5:Reserved<br>6:Reserved<br>7:Reserved<br>8:Reserved<br>9:Reserved<br>10:Reserved                       |
| 23:20         |                 | <b>GPIO21_MODE</b> | <b>Aux. mode of GPIO_21</b><br>0:GPIO21(IO)<br>1:URXDo(I)<br>2:EINT19(I)<br>3:SCL1(IO)<br>4:Reserved<br>5:PWM5(O)<br>6:Reserved<br>7:Reserved<br>8:Reserved<br>9:Reserved<br>10:Reserved                        |
| 7:4           |                 | <b>GPIO17_MODE</b> | <b>Aux. mode of GPIO_17</b><br>0:GPIO17(IO)<br>1:SPISLV_B_CS(I)<br>2:SPIMST_B_CS(I)<br>3:TDM_CK(IO)<br>4:PWM5(O)<br>5:CLKO3(O)<br>6:AUXADCo(ANAin)<br>7:Reserved<br>8:EINT17(I)<br>9:Reserved<br>10:BT_PRIo(IO) |
| 3:0           |                 | <b>GPIO16_MODE</b> | <b>Aux. mode of GPIO_16</b><br>0:GPIO16(IO)<br>1:SPISLV_B_SCK(I)<br>2:SPIMST_B_SCK(I)<br>3:TDM_WS(IO)<br>4:MA_MCo_DA3(IO)<br>5:SLV_MCo_DA3(IO)                                                                  |

| Bit(s) | Mnemonic | Name | Description                                                          |
|--------|----------|------|----------------------------------------------------------------------|
| 6:10   |          |      | 6:SDA1(IO)<br>7:Reserved<br>8:EINT16(I)<br>9:Reserved<br>10:Reserved |

| <b>A20B0050 GPIO MODEo SET      GPIO Mode Control</b> |                       |    |    |    |                       |    |    |    |                       |    |    |    |                       | <b>00000000</b> |                       |    |  |
|-------------------------------------------------------|-----------------------|----|----|----|-----------------------|----|----|----|-----------------------|----|----|----|-----------------------|-----------------|-----------------------|----|--|
| Bit                                                   | 31                    | 30 | 29 | 28 | 27                    | 26 | 25 | 24 | 23                    | 22 | 21 | 20 | 19                    | 18              | 17                    | 16 |  |
| <b>Name</b>                                           |                       |    |    |    |                       |    |    |    |                       |    |    |    |                       |                 | <b>GPIO4_MODE_SET</b> |    |  |
| <b>Type</b>                                           |                       |    |    |    |                       |    |    |    |                       |    |    |    |                       |                 | <b>WO</b>             |    |  |
| <b>Reset</b>                                          |                       |    |    |    |                       |    |    |    |                       |    |    |    | 0                     | 0               | 0                     | 0  |  |
| <b>Bit</b>                                            | 15                    | 14 | 13 | 12 | 11                    | 10 | 9  | 8  | 7                     | 6  | 5  | 4  | 3                     | 2               | 1                     | 0  |  |
| <b>Name</b>                                           | <b>GPIO3_MODE_SET</b> |    |    |    | <b>GPIO2_MODE_SET</b> |    |    |    | <b>GPIO1_MODE_SET</b> |    |    |    | <b>GPIOo_MODE_SET</b> |                 |                       |    |  |
| <b>Type</b>                                           | <b>WO</b>             |    |    |    | <b>WO</b>             |    |    |    | <b>WO</b>             |    |    |    | <b>WO</b>             |                 |                       |    |  |
| <b>Reset</b>                                          | 0                     | 0  | 0  | 0  | 0                     | 0  | 0  | 0  | 0                     | 0  | 0  | 0  | 0                     | 0               | 0                     | 0  |  |

| Bit(s) | Mnemonic | Name                  | Description                                                                         |
|--------|----------|-----------------------|-------------------------------------------------------------------------------------|
| 19:16  |          | <b>GPIO4_MODE_SET</b> | <b>Bitwise SET operation for auxiliary mode of GPIO_4</b><br>0: Keep<br>1: SET bits |
| 15:12  |          | <b>GPIO3_MODE_SET</b> | <b>Bitwise SET operation for auxiliary mode of GPIO_3</b><br>0: Keep<br>1: SET bits |
| 11:8   |          | <b>GPIO2_MODE_SET</b> | <b>Bitwise SET operation for auxiliary mode of GPIO_2</b><br>0: Keep<br>1: SET bits |
| 7:4    |          | <b>GPIO1_MODE_SET</b> | <b>Bitwise SET operation for auxiliary mode of GPIO_1</b><br>0: Keep<br>1: SET bits |
| 3:0    |          | <b>GPIOo_MODE_SET</b> | <b>Bitwise SET operation for auxiliary mode of GPIO_o</b><br>0: Keep<br>1: SET bits |

| <b>A20B0054 GPIO MODE1 SET      GPIO Mode Control</b> |                        |    |    |    |                        |    |    |    |                        |    |    |    |                        | <b>00000000</b> |           |    |  |
|-------------------------------------------------------|------------------------|----|----|----|------------------------|----|----|----|------------------------|----|----|----|------------------------|-----------------|-----------|----|--|
| Bit                                                   | 31                     | 30 | 29 | 28 | 27                     | 26 | 25 | 24 | 23                     | 22 | 21 | 20 | 19                     | 18              | 17        | 16 |  |
| <b>Name</b>                                           | <b>GPIO15_MODE_SET</b> |    |    |    | <b>GPIO14_MODE_SET</b> |    |    |    | <b>GPIO13_MODE_SET</b> |    |    |    | <b>GPIO12_MODE_SET</b> |                 |           |    |  |
| <b>Type</b>                                           |                        |    |    |    |                        |    |    |    |                        |    |    |    |                        |                 | <b>WO</b> |    |  |
| <b>Reset</b>                                          | 0                      | 0  | 0  | 0  | 0                      | 0  | 0  | 0  | 0                      | 0  | 0  | 0  | 0                      | 0               | 0         | 0  |  |
| <b>Bit</b>                                            | 15                     | 14 | 13 | 12 | 11                     | 10 | 9  | 8  | 7                      | 6  | 5  | 4  | 3                      | 2               | 1         | 0  |  |
| <b>Name</b>                                           | <b>GPIO11_MODE_SET</b> |    |    |    |                        |    |    |    |                        |    |    |    |                        |                 |           |    |  |
| <b>Type</b>                                           |                        |    |    |    |                        |    |    |    |                        |    |    |    |                        |                 |           |    |  |
| <b>Reset</b>                                          | 0                      | 0  | 0  | 0  |                        |    |    |    |                        |    |    |    |                        |                 |           |    |  |

| Bit(s) | Mnemonic | Name                   | Description                                                          |
|--------|----------|------------------------|----------------------------------------------------------------------|
| 31:28  |          | <b>GPIO15_MODE_SET</b> | <b>Bitwise SET operation for auxiliary mode of GPIO15</b><br>0: Keep |

| Bit(s) | Mnemonic | Name            | Description                                                                         |
|--------|----------|-----------------|-------------------------------------------------------------------------------------|
| 27:24  |          | GPIO14_MODE_SET | 1: SET bits<br><b>Bitwise SET operation for auxiliary mode of GPIO14</b><br>0: Keep |
| 23:20  |          | GPIO13_MODE_SET | 1: SET bits<br><b>Bitwise SET operation for auxiliary mode of GPIO13</b><br>0: Keep |
| 19:16  |          | GPIO12_MODE_SET | 1: SET bits<br><b>Bitwise SET operation for auxiliary mode of GPIO12</b><br>0: Keep |
| 15:12  |          | GPIO11_MODE_SET | 1: SET bits<br><b>Bitwise SET operation for auxiliary mode of GPIO11</b><br>0: Keep |

| A2oBoo58 GPIO MODE2 SET      GPIO Mode Control |                 |    |    |    |    |    |    |    |                 |    |    |    |    |    | oooooooooooo |    |  |  |
|------------------------------------------------|-----------------|----|----|----|----|----|----|----|-----------------|----|----|----|----|----|--------------|----|--|--|
| Bit                                            | 31              | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23              | 22 | 21 | 20 | 19 | 18 | 17           | 16 |  |  |
| Name                                           | GPIO22_MODE_SET |    |    |    |    |    |    |    | GPIO21_MODE_SET |    |    |    |    |    |              |    |  |  |
| Type                                           | WO              |    |    |    |    |    |    |    | WO              |    |    |    |    |    |              |    |  |  |
| Reset                                          |                 |    |    |    | 0  | 0  | 0  | 0  | 0               | 0  | 0  | 0  |    |    |              |    |  |  |
| Bit                                            | 15              | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7               | 6  | 5  | 4  | 3  | 2  | 1            | 0  |  |  |
| Name                                           | GPIO17_MODE_SET |    |    |    |    |    |    |    | GPIO16_MODE_SET |    |    |    |    |    |              |    |  |  |
| Type                                           | WO              |    |    |    |    |    |    |    | WO              |    |    |    |    |    |              |    |  |  |
| Reset                                          |                 |    |    |    |    |    |    |    | 0               | 0  | 0  | 0  | 0  | 0  | 0            | 0  |  |  |

| Bit(s) | Mnemonic | Name            | Description                                                                         |
|--------|----------|-----------------|-------------------------------------------------------------------------------------|
| 27:24  |          | GPIO22_MODE_SET | <b>Bitwise SET operation for auxiliary mode of GPIO22</b><br>0: Keep<br>1: SET bits |
| 23:20  |          | GPIO21_MODE_SET | <b>Bitwise SET operation for auxiliary mode of GPIO21</b><br>0: Keep<br>1: SET bits |
| 7:4    |          | GPIO17_MODE_SET | <b>Bitwise SET operation for auxiliary mode of GPIO17</b><br>0: Keep<br>1: SET bits |
| 3:0    |          | GPIO16_MODE_SET | <b>Bitwise SET operation for auxiliary mode of GPIO16</b><br>0: Keep<br>1: SET bits |

| A2oBoo60 GPIO MODEo CLR      GPIO Mode Control |                |    |    |    |                |    |    |    |                |    |    |    |                |    | oooooooooooo |    |  |  |
|------------------------------------------------|----------------|----|----|----|----------------|----|----|----|----------------|----|----|----|----------------|----|--------------|----|--|--|
| Bit                                            | 31             | 30 | 29 | 28 | 27             | 26 | 25 | 24 | 23             | 22 | 21 | 20 | 19             | 18 | 17           | 16 |  |  |
| Name                                           | GPIO4_MODE_CLR |    |    |    |                |    |    |    | WO             |    |    |    |                |    |              |    |  |  |
| Type                                           | WO             |    |    |    |                |    |    |    | WO             |    |    |    |                |    |              |    |  |  |
| Reset                                          |                |    |    |    |                |    |    |    | 0              | 0  | 0  | 0  |                |    |              |    |  |  |
| Bit                                            | 15             | 14 | 13 | 12 | 11             | 10 | 9  | 8  | 7              | 6  | 5  | 4  | 3              | 2  | 1            | 0  |  |  |
| Name                                           | GPIO3_MODE_CLR |    |    |    | GPIO2_MODE_CLR |    |    |    | GPIO1_MODE_CLR |    |    |    | GPIO0_MODE_CLR |    |              |    |  |  |
| Type                                           | WO             |    |    |    | WO             |    |    |    | WO             |    |    |    | WO             |    |              |    |  |  |

| Bit(s) | Mnemonic | Name           | Description                                                                             |
|--------|----------|----------------|-----------------------------------------------------------------------------------------|
| 19:16  |          | GPIO4_MODE_CLR | <b>Bitwise CLEAR operation for auxiliary mode of GPIO_4</b><br>0: Keep<br>1: Clear bits |
| 15:12  |          | GPIO3_MODE_CLR | <b>Bitwise CLEAR operation for auxiliary mode of GPIO_3</b><br>0: Keep<br>1: Clear bits |
| 11:8   |          | GPIO2_MODE_CLR | <b>Bitwise CLEAR operation for auxiliary mode of GPIO_2</b><br>0: Keep<br>1: Clear bits |
| 7:4    |          | GPIO1_MODE_CLR | <b>Bitwise CLEAR operation for auxiliary mode of GPIO_1</b><br>0: Keep<br>1: Clear bits |
| 3:0    |          | GPIOo_MODE_CLR | <b>Bitwise CLEAR operation for auxiliary mode of GPIO_o</b><br>0: Keep<br>1: Clear bits |

| Bit(s) | Mnemonic | Name            | Description                                                                             |
|--------|----------|-----------------|-----------------------------------------------------------------------------------------|
| 31:28  |          | GPIO15_MODE_CLR | <b>Bitwise CLEAR operation for auxiliary mode of GPIO15</b><br>0: Keep<br>1: Clear bits |
| 27:24  |          | GPIO14_MODE_CLR | <b>Bitwise CLEAR operation for auxiliary mode of GPIO14</b><br>0: Keep<br>1: Clear bits |
| 23:20  |          | GPIO13_MODE_CLR | <b>Bitwise CLEAR operation for auxiliary mode of GPIO13</b><br>0: Keep<br>1: Clear bits |
| 19:16  |          | GPIO12_MODE_CLR | <b>Bitwise CLEAR operation for auxiliary mode of GPIO12</b><br>0: Keep<br>1: Clear bits |
| 15:12  |          | GPIO11_MODE_CLR | <b>Bitwise CLEAR operation for auxiliary mode of GPIO11</b><br>0: Keep<br>1: Clear bits |

| Bit(s)   | Mnemonic                                        | Name                     | Description            |
|----------|-------------------------------------------------|--------------------------|------------------------|
| A20Boo68 | <u>GPIO_MODE2_CLR</u>                           | <b>GPIO Mode Control</b> | <b>oooooooooo</b>      |
| Bit      | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |                          |                        |
| Name     |                                                 | <b>GPIO22_MODE_CLR</b>   | <b>GPIO21_MODE_CLR</b> |
| Type     |                                                 | WO                       | WO                     |
| Reset    |                                                 | 0 0 0 0                  | 0 0 0 0                |
| Bit      | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0           |                          |                        |
| Name     |                                                 | <b>GPIO17_MODE_CLR</b>   | <b>GPIO16_MODE_CLR</b> |
| Type     |                                                 | WO                       | WO                     |
| Reset    |                                                 | 0 0 0 0                  | 0 0 0 0                |

| Bit(s) | Mnemonic | Name                   | Description                                                 |
|--------|----------|------------------------|-------------------------------------------------------------|
| 27:24  |          | <b>GPIO22_MODE_CLR</b> | <b>Bitwise CLEAR operation for auxiliary mode of GPIO22</b> |
|        |          |                        | 0: Keep<br>1: Clear bits                                    |
| 23:20  |          | <b>GPIO21_MODE_CLR</b> | <b>Bitwise CLEAR operation for auxiliary mode of GPIO21</b> |
|        |          |                        | 0: Keep<br>1: Clear bits                                    |
| 7:4    |          | <b>GPIO17_MODE_CLR</b> | <b>Bitwise CLEAR operation for auxiliary mode of GPIO17</b> |
|        |          |                        | 0: Keep<br>1: Clear bits                                    |
| 3:0    |          | <b>GPIO16_MODE_CLR</b> | <b>Bitwise CLEAR operation for auxiliary mode of GPIO16</b> |
|        |          |                        | 0: Keep<br>1: Clear bits                                    |

| Bit(s)   | Mnemonic                                        | Name | driving current         | Description             |
|----------|-------------------------------------------------|------|-------------------------|-------------------------|
| A20Coooo | <u>DRV_CFG0</u>                                 |      |                         | <b>oooooooooo</b>       |
| Bit      | 31 30 29 28 27 26 25 24 23 22 21 20 19 18 17 16 |      |                         |                         |
| Name     |                                                 |      | <b>drv_cfg_g_pio_22</b> | <b>drv_cfg_g_pio_21</b> |
| Type     |                                                 |      | RW                      | RW                      |
| Reset    | 0 0 0 0 0 0                                     | 0 0  | 0 0                     | 0 0                     |
| Bit      | 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0           |      |                         |                         |
| Name     |                                                 |      | <b>drv_cfg_g_pio_4</b>  | <b>drv_cfg_g_pio_3</b>  |
| Type     |                                                 |      | RW                      | RW                      |
| Reset    | 0 0 0 0 0 0                                     | 0 0  | 0 0                     | 0 0                     |
|          |                                                 |      | <b>drv_cfg_g_pio_2</b>  | <b>drv_cfg_g_pio_1</b>  |
|          |                                                 |      | RW                      | RW                      |
|          |                                                 |      | <b>drv_cfg_g_pio_0</b>  |                         |
|          |                                                 |      | RW                      |                         |
|          |                                                 |      |                         |                         |

| Bit(s) | Mnemonic | Name                   | Description                                        |
|--------|----------|------------------------|----------------------------------------------------|
| 25:24  |          | <b>drv_cfg_gpio_22</b> | <b>PAD_GPIO_22</b>                                 |
|        |          |                        | 4mA: [00]<br>8mA: [10]<br>12mA: [01]<br>16mA: [11] |
| 23:22  |          | <b>drv_cfg_gpio_21</b> | <b>PAD_GPIO_21</b>                                 |

| Bit(s) | Mnemonic       | Name              | Description                                        |
|--------|----------------|-------------------|----------------------------------------------------|
|        |                |                   | 4mA: [oo]<br>8mA: [10]<br>12mA: [01]<br>16mA: [11] |
| 9:8    | drv_cfg_gpio_4 | <b>PAD_GPIO_4</b> | 4mA: [oo]<br>8mA: [10]<br>12mA: [01]<br>16mA: [11] |
| 7:6    | drv_cfg_gpio_3 | <b>PAD_GPIO_3</b> | 4mA: [oo]<br>8mA: [10]<br>12mA: [01]<br>16mA: [11] |
| 5:4    | drv_cfg_gpio_2 | <b>PAD_GPIO_2</b> | 4mA: [oo]<br>8mA: [10]<br>12mA: [01]<br>16mA: [11] |
| 3:2    | drv_cfg_gpio_1 | <b>PAD_GPIO_1</b> | 4mA: [oo]<br>8mA: [10]<br>12mA: [01]<br>16mA: [11] |
| 1:0    | drv_cfg_gpio_0 | <b>PAD_GPIO_0</b> | 4mA: [oo]<br>8mA: [10]<br>12mA: [01]<br>16mA: [11] |

| <b>A20C0004 DRV_CFG0_SET</b> |    |    |    |    |    | <b>Set for DRV_CFG0</b> |                  |                  |    |    |    |    |    | <b>oooooooooooo</b> |    |    |  |  |  |  |  |
|------------------------------|----|----|----|----|----|-------------------------|------------------|------------------|----|----|----|----|----|---------------------|----|----|--|--|--|--|--|
| Bit                          | 31 | 30 | 29 | 28 | 27 | 26                      | 25               | 24               | 23 | 22 | 21 | 20 | 19 | 18                  | 17 | 16 |  |  |  |  |  |
| <b>Name</b>                  |    |    |    |    |    |                         | <b>drv_cfg_s</b> | <b>drv_cfg_s</b> |    |    |    |    |    |                     |    |    |  |  |  |  |  |
| <b>Type</b>                  |    |    |    |    |    |                         | <b>et_gpio_2</b> | <b>et_gpio_2</b> |    |    |    |    |    |                     |    |    |  |  |  |  |  |
| <b>Rese</b>                  | 0  | 0  | 0  | 0  | 0  | 0                       | 0                | 0                | 0  | 0  | 0  | 0  | 0  | 0                   | 0  | 0  |  |  |  |  |  |

| t     |    |    |    |    |    |    |                        |   |                        |   |                        |   |                        |   |                        |   |
|-------|----|----|----|----|----|----|------------------------|---|------------------------|---|------------------------|---|------------------------|---|------------------------|---|
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9                      | 8 | 7                      | 6 | 5                      | 4 | 3                      | 2 | 1                      | 0 |
| Name  |    |    |    |    |    |    | drv_cfg_c<br>et_gpio_4 |   | drv_cfg_c<br>et_gpio_3 |   | drv_cfg_c<br>et_gpio_2 |   | drv_cfg_c<br>et_gpio_1 |   | drv_cfg_c<br>et_gpio_0 |   |
| Type  |    |    |    |    |    |    |                        |   | WO                     |   | WO                     |   | WO                     |   | WO                     |   |
| Reset |    |    |    |    |    |    | 0                      | 0 | 0                      | 0 | 0                      | 0 | 0                      | 0 | 0                      | 0 |

| Bit(s) | Mnemonic | Name                | Description                                |
|--------|----------|---------------------|--------------------------------------------|
| 25:24  |          | drv_cfg_set_gpio_22 | <b>PAD_GPIO_22</b><br>0: Keep; 1: SET bit; |
| 23:22  |          | drv_cfg_set_gpio_21 | <b>PAD_GPIO_21</b><br>0: Keep; 1: SET bit; |
| 9:8    |          | drv_cfg_set_gpio_4  | <b>PAD_GPIO_4</b><br>0: Keep; 1: SET bit;  |
| 7:6    |          | drv_cfg_set_gpio_3  | <b>PAD_GPIO_3</b><br>0: Keep; 1: SET bit;  |
| 5:4    |          | drv_cfg_set_gpio_2  | <b>PAD_GPIO_2</b><br>0: Keep; 1: SET bit;  |
| 3:2    |          | drv_cfg_set_gpio_1  | <b>PAD_GPIO_1</b><br>0: Keep; 1: SET bit;  |
| 1:0    |          | drv_cfg_set_gpio_0  | <b>PAD_GPIO_0</b><br>0: Keep; 1: SET bit;  |

| A20C0008 DRV_CFG0 CLR |    |    |    |    |    |    |                        |    |                        | clear for DRV_CFG0 |                        |    |                        |    |                        |    |  |
|-----------------------|----|----|----|----|----|----|------------------------|----|------------------------|--------------------|------------------------|----|------------------------|----|------------------------|----|--|
| Bit                   | 31 | 30 | 29 | 28 | 27 | 26 | 25                     | 24 | 23                     | 22                 | 21                     | 20 | 19                     | 18 | 17                     | 16 |  |
| Name                  |    |    |    |    |    |    | drv_cfg_c<br>lr_gpio_2 |    | drv_cfg_c<br>lr_gpio_1 |                    |                        |    |                        |    |                        |    |  |
| Type                  |    |    |    |    |    |    |                        |    | WO                     |                    | WO                     |    |                        |    |                        |    |  |
| Reset                 |    |    |    |    |    |    | 0                      | 0  | 0                      | 0                  |                        |    |                        |    |                        |    |  |
| Bit                   | 15 | 14 | 13 | 12 | 11 | 10 | 9                      | 8  | 7                      | 6                  | 5                      | 4  | 3                      | 2  | 1                      | 0  |  |
| Name                  |    |    |    |    |    |    | drv_cfg_c<br>lr_gpio_4 |    | drv_cfg_c<br>lr_gpio_3 |                    | drv_cfg_c<br>lr_gpio_2 |    | drv_cfg_c<br>lr_gpio_1 |    | drv_cfg_c<br>lr_gpio_0 |    |  |
| Type                  |    |    |    |    |    |    |                        |    | WO                     |                    | WO                     |    | WO                     |    | WO                     |    |  |
| Reset                 |    |    |    |    |    |    | 0                      | 0  | 0                      | 0                  | 0                      | 0  | 0                      | 0  | 0                      | 0  |  |

| Bit(s) | Mnemonic | Name                | Description                                 |
|--------|----------|---------------------|---------------------------------------------|
| 25:24  |          | drv_cfg_clr_gpio_22 | <b>PAD_GPIO_22</b><br>0: Keep; 1: Clear bit |

| Bit(s) | Mnemonic            | Name                  | Description |
|--------|---------------------|-----------------------|-------------|
| 23:22  | drv_cfg_clr_gpio_21 | <b>PAD_GPIO_21</b>    |             |
|        |                     | o: Keep; 1: Clear bit |             |
| 9:8    | drv_cfg_clr_gpio_4  | <b>PAD_GPIO_4</b>     |             |
|        |                     | o: Keep; 1: Clear bit |             |
| 7:6    | drv_cfg_clr_gpio_3  | <b>PAD_GPIO_3</b>     |             |
|        |                     | o: Keep; 1: Clear bit |             |
| 5:4    | drv_cfg_clr_gpio_2  | <b>PAD_GPIO_2</b>     |             |
|        |                     | o: Keep; 1: Clear bit |             |
| 3:2    | drv_cfg_clr_gpio_1  | <b>PAD_GPIO_1</b>     |             |
|        |                     | o: Keep; 1: Clear bit |             |
| 1:0    | drv_cfg_clr_gpio_0  | <b>PAD_GPIO_0</b>     |             |
|        |                     | o: Keep; 1: Clear bit |             |

| <b>A20C0010 G_CFG0</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>0000000F</b> |                     |                     |                     |                     |
|------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|---------------------|---------------------|---------------------|---------------------|
| Bit                    | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17              | 16                  |                     |                     |                     |
| Name                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |                     |                     |                     |                     |
| Type                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |                     |                     |                     |                     |
| Reset                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |                     |                     |                     |                     |
| Bit                    | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1               | 0                   |                     |                     |                     |
| Name                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 | <b>g_cfg_gpio_3</b> | <b>g_cfg_gpio_2</b> | <b>g_cfg_gpio_1</b> | <b>g_cfg_gpio_0</b> |
| Type                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 | RW                  | RW                  | RW                  | RW                  |
| Reset                  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 | 1                   | 1                   | 1                   | 1                   |

| Bit(s) | Mnemonic | Name                           | Description       |
|--------|----------|--------------------------------|-------------------|
| 3      |          | <b>g_cfg_gpio_3</b>            | <b>PAD_GPIO_3</b> |
|        |          | o: Enable AIO; 1: Disable AIO; |                   |
| 2      |          | <b>g_cfg_gpio_2</b>            | <b>PAD_GPIO_2</b> |
|        |          | o: Enable AIO; 1: Disable AIO; |                   |
| 1      |          | <b>g_cfg_gpio_1</b>            | <b>PAD_GPIO_1</b> |
|        |          | o: Enable AIO; 1: Disable AIO; |                   |
| 0      |          | <b>g_cfg_gpio_0</b>            | <b>PAD_GPIO_0</b> |
|        |          | o: Enable AIO; 1: Disable AIO; |                   |

| <b>A20C0014 G_CFG0_SET</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>00000000</b> |                         |                         |                         |                         |
|----------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|-------------------------|-------------------------|-------------------------|-------------------------|
| Bit                        | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17              | 16                      |                         |                         |                         |
| Name                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |                         |                         |                         |                         |
| Type                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |                         |                         |                         |                         |
| Reset                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |                         |                         |                         |                         |
| Bit                        | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1               | 0                       |                         |                         |                         |
| Name                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 | <b>g_cfg_set_gpio_3</b> | <b>g_cfg_set_gpio_2</b> | <b>g_cfg_set_gpio_1</b> | <b>g_cfg_set_gpio_0</b> |

| Type  |  |  |  |  |  |  |  |  |  |  |  |  | 3  | 2  | 1  | 0  |
|-------|--|--|--|--|--|--|--|--|--|--|--|--|----|----|----|----|
| Reset |  |  |  |  |  |  |  |  |  |  |  |  | WO | WO | WO | WO |

| Bit(s) | Mnemonic | Name             | Description                               |
|--------|----------|------------------|-------------------------------------------|
| 3      |          | g_cfg_set_gpio_3 | <b>PAD_GPIO_3</b><br>o: Keep; 1: SET bit; |
| 2      |          | g_cfg_set_gpio_2 | <b>PAD_GPIO_2</b><br>o: Keep; 1: SET bit; |
| 1      |          | g_cfg_set_gpio_1 | <b>PAD_GPIO_1</b><br>o: Keep; 1: SET bit; |
| 0      |          | g_cfg_set_gpio_0 | <b>PAD_GPIO_0</b><br>o: Keep; 1: SET bit; |

**A20C0018 G CFG0 CLR 00000000**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    | 0  | 0  | 0  | 0  |

| Bit(s) | Mnemonic | Name             | Description                                |
|--------|----------|------------------|--------------------------------------------|
| 3      |          | g_cfg_clr_gpio_3 | <b>PAD_GPIO_3</b><br>o: Keep; 1: Clear bit |
| 2      |          | g_cfg_clr_gpio_2 | <b>PAD_GPIO_2</b><br>o: Keep; 1: Clear bit |
| 1      |          | g_cfg_clr_gpio_1 | <b>PAD_GPIO_1</b><br>o: Keep; 1: Clear bit |
| 0      |          | g_cfg_clr_gpio_0 | <b>PAD_GPIO_0</b><br>o: Keep; 1: Clear bit |

**A20C0020 IES CFG0 00001FFF**

| Bit   | 31 | 30 | 29 | 28 | 27                                       | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|------------------------------------------|----|----|----|----|----|----|----|----|----|----|----|
| Name  |    |    |    |    |                                          |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |                                          |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |                                          |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11                                       | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |                                          |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |                                          |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    | ies_cfies_cf<br>g_gpi g_gpi<br>o_22 o_21 |    |    |    |    |    |    |    | RW | RW | RW | RW |

| Bit(s) | Mnemonic | Name            | Description                                  |
|--------|----------|-----------------|----------------------------------------------|
| 12     |          | ies_cfg_gpio_22 | <b>PAD_GPIO_22</b><br>o: Disable; 1: Enable; |
| 11     |          | ies_cfg_gpio_21 | <b>PAD_GPIO_21</b>                           |

| Bit(s) | Mnemonic | Name           | Description                                 |
|--------|----------|----------------|---------------------------------------------|
| 4      |          | ies_cfg_gpio_4 | o: Disable; 1: Enable;<br><b>PAD_GPIO_4</b> |
| 3      |          | ies_cfg_gpio_3 | o: Disable; 1: Enable;<br><b>PAD_GPIO_3</b> |
| 2      |          | ies_cfg_gpio_2 | o: Disable; 1: Enable;<br><b>PAD_GPIO_2</b> |
| 1      |          | ies_cfg_gpio_1 | o: Disable; 1: Enable;<br><b>PAD_GPIO_1</b> |
| 0      |          | ies_cfg_gpio_o | o: Disable; 1: Enable;<br><b>PAD_GPIO_o</b> |

| <b>A20C0024 IES CFGo SET</b> |    |                      |    |                      |    |    |    |    |    |    |    |                     |    |                     |    | <b>00000000</b>     |  |                     |  |                     |  |    |  |  |
|------------------------------|----|----------------------|----|----------------------|----|----|----|----|----|----|----|---------------------|----|---------------------|----|---------------------|--|---------------------|--|---------------------|--|----|--|--|
| Bit                          | 31 | 30                   | 29 | 28                   | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20                  | 19 | 18                  | 17 | 16                  |  |                     |  |                     |  |    |  |  |
| <b>Name</b>                  |    |                      |    |                      |    |    |    |    |    |    |    |                     |    |                     |    |                     |  |                     |  |                     |  |    |  |  |
| <b>Type</b>                  |    |                      |    |                      |    |    |    |    |    |    |    |                     |    |                     |    |                     |  |                     |  |                     |  |    |  |  |
| <b>Reset</b>                 |    |                      |    |                      |    |    |    |    |    |    |    |                     |    |                     |    |                     |  |                     |  |                     |  |    |  |  |
| Bit                          | 15 | 14                   | 13 | 12                   | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4                   | 3  | 2                   | 1  | 0                   |  |                     |  |                     |  |    |  |  |
| <b>Name</b>                  |    | ies_cf <sub>22</sub> |    | ies_cf <sub>21</sub> |    |    |    |    |    |    |    | ies_cf <sub>4</sub> |    | ies_cf <sub>3</sub> |    | ies_cf <sub>2</sub> |  | ies_cf <sub>1</sub> |  | ies_cf <sub>0</sub> |  |    |  |  |
| <b>Type</b>                  |    | WO                   |    | WO                   |    |    |    |    |    |    |    | WO                  |    | WO                  |    | WO                  |  | WO                  |  | WO                  |  | WO |  |  |
| <b>Reset</b>                 |    | 0                    |    | 0                    |    |    |    |    |    |    |    | 0                   |    | 0                   |    | 0                   |  | 0                   |  | 0                   |  | 0  |  |  |

| Bit(s) | Mnemonic | Name                | Description                                |
|--------|----------|---------------------|--------------------------------------------|
| 12     |          | ies_cfg_set_gpio_22 | <b>PAD_GPIO_22</b><br>o: Keep; 1: SET bit; |
| 11     |          | ies_cfg_set_gpio_21 | <b>PAD_GPIO_21</b><br>o: Keep; 1: SET bit; |
| 4      |          | ies_cfg_set_gpio_4  | <b>PAD_GPIO_4</b><br>o: Keep; 1: SET bit;  |
| 3      |          | ies_cfg_set_gpio_3  | <b>PAD_GPIO_3</b><br>o: Keep; 1: SET bit;  |
| 2      |          | ies_cfg_set_gpio_2  | <b>PAD_GPIO_2</b><br>o: Keep; 1: SET bit;  |
| 1      |          | ies_cfg_set_gpio_1  | <b>PAD_GPIO_1</b><br>o: Keep; 1: SET bit;  |
| 0      |          | ies_cfg_set_gpio_o  | <b>PAD_GPIO_o</b><br>o: Keep; 1: SET bit;  |

| <b>A20C0028 IES CFGo CLR</b> |    |                      |    |                      |    |    |    |    |    |    |    |                     |    |                     |    | <b>00000000</b>     |  |                     |  |                     |  |    |  |  |
|------------------------------|----|----------------------|----|----------------------|----|----|----|----|----|----|----|---------------------|----|---------------------|----|---------------------|--|---------------------|--|---------------------|--|----|--|--|
| Bit                          | 31 | 30                   | 29 | 28                   | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20                  | 19 | 18                  | 17 | 16                  |  |                     |  |                     |  |    |  |  |
| <b>Name</b>                  |    |                      |    |                      |    |    |    |    |    |    |    |                     |    |                     |    |                     |  |                     |  |                     |  |    |  |  |
| <b>Type</b>                  |    |                      |    |                      |    |    |    |    |    |    |    |                     |    |                     |    |                     |  |                     |  |                     |  |    |  |  |
| <b>Reset</b>                 |    |                      |    |                      |    |    |    |    |    |    |    |                     |    |                     |    |                     |  |                     |  |                     |  |    |  |  |
| Bit                          | 15 | 14                   | 13 | 12                   | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4                   | 3  | 2                   | 1  | 0                   |  |                     |  |                     |  |    |  |  |
| <b>Name</b>                  |    | ies_cf <sub>22</sub> |    | ies_cf <sub>21</sub> |    |    |    |    |    |    |    | ies_cf <sub>4</sub> |    | ies_cf <sub>3</sub> |    | ies_cf <sub>2</sub> |  | ies_cf <sub>1</sub> |  | ies_cf <sub>0</sub> |  |    |  |  |
| <b>Type</b>                  |    | WO                   |    | WO                   |    |    |    |    |    |    |    | WO                  |    | WO                  |    | WO                  |  | WO                  |  | WO                  |  | WO |  |  |
| <b>Reset</b>                 |    | 0                    |    | 0                    |    |    |    |    |    |    |    | 0                   |    | 0                   |    | 0                   |  | 0                   |  | 0                   |  | 0  |  |  |

| Bit(s) | Mnemonic | Name                | Description                                 |
|--------|----------|---------------------|---------------------------------------------|
| 12     |          | ies_cfg_clr_gpio_22 | <b>PAD_GPIO_22</b><br>o: Keep; 1: Clear bit |
| 11     |          | ies_cfg_clr_gpio_21 | <b>PAD_GPIO_21</b><br>o: Keep; 1: Clear bit |
| 4      |          | ies_cfg_clr_gpio_4  | <b>PAD_GPIO_4</b><br>o: Keep; 1: Clear bit  |
| 3      |          | ies_cfg_clr_gpio_3  | <b>PAD_GPIO_3</b><br>o: Keep; 1: Clear bit  |
| 2      |          | ies_cfg_clr_gpio_2  | <b>PAD_GPIO_2</b><br>o: Keep; 1: Clear bit  |
| 1      |          | ies_cfg_clr_gpio_1  | <b>PAD_GPIO_1</b><br>o: Keep; 1: Clear bit  |
| 0      |          | ies_cfg_clr_gpio_o  | <b>PAD_GPIO_O</b><br>o: Keep; 1: Clear bit  |

| <b>A20C0030 PD CFGO</b> |    |    |                        |    |                        |    |    |    |    |    |                       |    |                       |    |                       | <b>000017FF</b> |                       |  |  |
|-------------------------|----|----|------------------------|----|------------------------|----|----|----|----|----|-----------------------|----|-----------------------|----|-----------------------|-----------------|-----------------------|--|--|
| Bit                     | 31 | 30 | 29                     | 28 | 27                     | 26 | 25 | 24 | 23 | 22 | 21                    | 20 | 19                    | 18 | 17                    | 16              |                       |  |  |
| Name                    |    |    |                        |    |                        |    |    |    |    |    |                       |    |                       |    |                       |                 |                       |  |  |
| Type                    |    |    |                        |    |                        |    |    |    |    |    |                       |    |                       |    |                       |                 |                       |  |  |
| Reset                   |    |    |                        |    |                        |    |    |    |    |    |                       |    |                       |    |                       |                 |                       |  |  |
| Bit                     | 15 | 14 | 13                     | 12 | 11                     | 10 | 9  | 8  | 7  | 6  | 5                     | 4  | 3                     | 2  | 1                     | 0               |                       |  |  |
| Name                    |    |    | <b>pd_cf_g_gpio_22</b> |    | <b>pd_cf_g_gpio_21</b> |    |    |    |    |    | <b>pd_cf_g_gpio_4</b> |    | <b>pd_cf_g_gpio_3</b> |    | <b>pd_cf_g_gpio_2</b> |                 | <b>pd_cf_g_gpio_1</b> |  |  |
| Type                    |    |    | RW                     |    | RW                     |    |    |    |    |    | RW                    |    | RW                    |    | RW                    |                 | RW                    |  |  |
| Reset                   |    |    | 1                      |    | 0                      |    | 1  |    | 1  |    | 1                     |    | 1                     |    | 1                     |                 | 1                     |  |  |

| Bit(s) | Mnemonic | Name           | Description                                  |
|--------|----------|----------------|----------------------------------------------|
| 12     |          | pd_cfg_gpio_22 | <b>PAD_GPIO_22</b><br>o: Disable; 1: Enable; |
| 11     |          | pd_cfg_gpio_21 | <b>PAD_GPIO_21</b><br>o: Disable; 1: Enable; |
| 4      |          | pd_cfg_gpio_4  | <b>PAD_GPIO_4</b><br>o: Disable; 1: Enable;  |
| 3      |          | pd_cfg_gpio_3  | <b>PAD_GPIO_3</b><br>o: Disable; 1: Enable;  |
| 2      |          | pd_cfg_gpio_2  | <b>PAD_GPIO_2</b><br>o: Disable; 1: Enable;  |
| 1      |          | pd_cfg_gpio_1  | <b>PAD_GPIO_1</b><br>o: Disable; 1: Enable;  |
| 0      |          | pd_cfg_gpio_o  | <b>PAD_GPIO_O</b><br>o: Disable; 1: Enable;  |

| <b>A20C0034 PD CFGO SET</b> |    |    |                            |    |                            |    |    |    |    |    |                           |    |                           |    |                           | <b>00000000</b> |                           |  |  |
|-----------------------------|----|----|----------------------------|----|----------------------------|----|----|----|----|----|---------------------------|----|---------------------------|----|---------------------------|-----------------|---------------------------|--|--|
| Bit                         | 31 | 30 | 29                         | 28 | 27                         | 26 | 25 | 24 | 23 | 22 | 21                        | 20 | 19                        | 18 | 17                        | 16              |                           |  |  |
| Name                        |    |    |                            |    |                            |    |    |    |    |    |                           |    |                           |    |                           |                 |                           |  |  |
| Type                        |    |    |                            |    |                            |    |    |    |    |    |                           |    |                           |    |                           |                 |                           |  |  |
| Reset                       |    |    |                            |    |                            |    |    |    |    |    |                           |    |                           |    |                           |                 |                           |  |  |
| Bit                         | 15 | 14 | 13                         | 12 | 11                         | 10 | 9  | 8  | 7  | 6  | 5                         | 4  | 3                         | 2  | 1                         | 0               |                           |  |  |
| Name                        |    |    | <b>pd_cf_g_set_gpio_22</b> |    | <b>pd_cf_g_set_gpio_21</b> |    |    |    |    |    | <b>pd_cf_g_set_gpio_4</b> |    | <b>pd_cf_g_set_gpio_3</b> |    | <b>pd_cf_g_set_gpio_2</b> |                 | <b>pd_cf_g_set_gpio_1</b> |  |  |
| Type                        |    |    | WO                         |    | WO                         |    |    |    |    |    | WO                        |    | WO                        |    | WO                        |                 | WO                        |  |  |

|       |   |   |   |   |   |   |   |   |   |   |   |   |   |
|-------|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|-------|---|---|---|---|---|---|---|---|---|---|---|---|---|

| Bit(s) | Mnemonic           | Name               | Description          |
|--------|--------------------|--------------------|----------------------|
| 12     | pd_cfg_set_gpio_22 | <b>PAD_GPIO_22</b> | o: Keep; 1: SET bit; |
| 11     | pd_cfg_set_gpio_21 | <b>PAD_GPIO_21</b> | o: Keep; 1: SET bit; |
| 4      | pd_cfg_set_gpio_4  | <b>PAD_GPIO_4</b>  | o: Keep; 1: SET bit; |
| 3      | pd_cfg_set_gpio_3  | <b>PAD_GPIO_3</b>  | o: Keep; 1: SET bit; |
| 2      | pd_cfg_set_gpio_2  | <b>PAD_GPIO_2</b>  | o: Keep; 1: SET bit; |
| 1      | pd_cfg_set_gpio_1  | <b>PAD_GPIO_1</b>  | o: Keep; 1: SET bit; |
| 0      | pd_cfg_set_gpio_o  | <b>PAD_GPIO_o</b>  | o: Keep; 1: SET bit; |

**A20C0038 PD CFGo CLR 00000000**

| Bit   | 31 | 30 | 29                  | 28                  | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20                 | 19                 | 18                 | 17                 | 16                 |
|-------|----|----|---------------------|---------------------|----|----|----|----|----|----|----|--------------------|--------------------|--------------------|--------------------|--------------------|
| Name  |    |    |                     |                     |    |    |    |    |    |    |    |                    |                    |                    |                    |                    |
| Type  |    |    |                     |                     |    |    |    |    |    |    |    |                    |                    |                    |                    |                    |
| Reset |    |    |                     |                     |    |    |    |    |    |    |    |                    |                    |                    |                    |                    |
| Bit   | 15 | 14 | 13                  | 12                  | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4                  | 3                  | 2                  | 1                  | 0                  |
| Name  |    |    | pd_cf_g_clr_gpio_22 | pd_cf_g_clr_gpio_21 |    |    |    |    |    |    |    | pd_cf_g_clr_gpio_4 | pd_cf_g_clr_gpio_3 | pd_cf_g_clr_gpio_2 | pd_cf_g_clr_gpio_1 | pd_cf_g_clr_gpio_0 |
| Type  |    |    | WO                  | WO                  |    |    |    |    |    |    |    | WO                 | WO                 | WO                 | WO                 | WO                 |
| Reset |    |    | 0                   | 0                   |    |    |    |    |    |    |    | 0                  | 0                  | 0                  | 0                  | 0                  |

| Bit(s) | Mnemonic           | Name               | Description           |
|--------|--------------------|--------------------|-----------------------|
| 12     | pd_cfg_clr_gpio_22 | <b>PAD_GPIO_22</b> | o: Keep; 1: Clear bit |
| 11     | pd_cfg_clr_gpio_21 | <b>PAD_GPIO_21</b> | o: Keep; 1: Clear bit |
| 4      | pd_cfg_clr_gpio_4  | <b>PAD_GPIO_4</b>  | o: Keep; 1: Clear bit |
| 3      | pd_cfg_clr_gpio_3  | <b>PAD_GPIO_3</b>  | o: Keep; 1: Clear bit |
| 2      | pd_cfg_clr_gpio_2  | <b>PAD_GPIO_2</b>  | o: Keep; 1: Clear bit |
| 1      | pd_cfg_clr_gpio_1  | <b>PAD_GPIO_1</b>  | o: Keep; 1: Clear bit |
| 0      | pd_cfg_clr_gpio_o  | <b>PAD_GPIO_o</b>  | o: Keep; 1: Clear bit |

**A20C0040 PU CFGo 00000800**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |

|              |  |                        |                        |   |   |   |   |   |   |                       |                       |                       |                       |                       |
|--------------|--|------------------------|------------------------|---|---|---|---|---|---|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|
| <b>Name</b>  |  | <b>pu_cf_g_gpio_22</b> | <b>pu_cf_g_gpio_21</b> |   |   |   |   |   |   | <b>pu_cf_g_gpio_4</b> | <b>pu_cf_g_gpio_3</b> | <b>pu_cf_g_gpio_2</b> | <b>pu_cf_g_gpio_1</b> | <b>pu_cf_g_gpio_0</b> |
| <b>Type</b>  |  | RW                     | RW                     |   |   |   |   |   |   | RW                    | RW                    | RW                    | RW                    | RW                    |
| <b>Reset</b> |  | 0                      | 1                      | 0 | 0 | 0 | 0 | 0 | 0 | 0                     | 0                     | 0                     | 0                     | 0                     |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b>    | <b>Description</b>                           |
|---------------|-----------------|----------------|----------------------------------------------|
| 12            |                 | pu_cfg_gpio_22 | <b>PAD_GPIO_22</b><br>0: Disable; 1: Enable; |
| 11            |                 | pu_cfg_gpio_21 | <b>PAD_GPIO_21</b><br>0: Disable; 1: Enable; |
| 4             |                 | pu_cfg_gpio_4  | <b>PAD_GPIO_4</b><br>0: Disable; 1: Enable;  |
| 3             |                 | pu_cfg_gpio_3  | <b>PAD_GPIO_3</b><br>0: Disable; 1: Enable;  |
| 2             |                 | pu_cfg_gpio_2  | <b>PAD_GPIO_2</b><br>0: Disable; 1: Enable;  |
| 1             |                 | pu_cfg_gpio_1  | <b>PAD_GPIO_1</b><br>0: Disable; 1: Enable;  |
| 0             |                 | pu_cfg_gpio_0  | <b>PAD_GPIO_0</b><br>0: Disable; 1: Enable;  |

| <b>A20C0044 PU CFG0 SET</b> |    |    |    |                            |                            |    |    |    |    |    |    |                           |                           |                           | <b>00000000</b>           |                           |  |  |  |
|-----------------------------|----|----|----|----------------------------|----------------------------|----|----|----|----|----|----|---------------------------|---------------------------|---------------------------|---------------------------|---------------------------|--|--|--|
| <b>Bit</b>                  | 31 | 30 | 29 | 28                         | 27                         | 26 | 25 | 24 | 23 | 22 | 21 | 20                        | 19                        | 18                        | 17                        | 16                        |  |  |  |
| <b>Name</b>                 |    |    |    |                            |                            |    |    |    |    |    |    |                           |                           |                           |                           |                           |  |  |  |
| <b>Type</b>                 |    |    |    |                            |                            |    |    |    |    |    |    |                           |                           |                           |                           |                           |  |  |  |
| <b>Reset</b>                |    |    |    |                            |                            |    |    |    |    |    |    |                           |                           |                           |                           |                           |  |  |  |
| <b>Bit</b>                  | 15 | 14 | 13 | 12                         | 11                         | 10 | 9  | 8  | 7  | 6  | 5  | 4                         | 3                         | 2                         | 1                         | 0                         |  |  |  |
| <b>Name</b>                 |    |    |    | <b>pu_cf_g_set_gpio_22</b> | <b>pu_cf_g_set_gpio_21</b> |    |    |    |    |    |    | <b>pu_cf_g_set_gpio_4</b> | <b>pu_cf_g_set_gpio_3</b> | <b>pu_cf_g_set_gpio_2</b> | <b>pu_cf_g_set_gpio_1</b> | <b>pu_cf_g_set_gpio_0</b> |  |  |  |
| <b>Type</b>                 |    |    |    | WO                         | WO                         |    |    |    |    |    |    | WO                        | WO                        | WO                        | WO                        | WO                        |  |  |  |
| <b>Reset</b>                |    |    |    | 0                          | 0                          |    |    |    |    |    |    | 0                         | 0                         | 0                         | 0                         | 0                         |  |  |  |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b>        | <b>Description</b>                         |
|---------------|-----------------|--------------------|--------------------------------------------|
| 12            |                 | pu_cfg_set_gpio_22 | <b>PAD_GPIO_22</b><br>0: Keep; 1: SET bit; |
| 11            |                 | pu_cfg_set_gpio_21 | <b>PAD_GPIO_21</b><br>0: Keep; 1: SET bit; |
| 4             |                 | pu_cfg_set_gpio_4  | <b>PAD_GPIO_4</b><br>0: Keep; 1: SET bit;  |
| 3             |                 | pu_cfg_set_gpio_3  | <b>PAD_GPIO_3</b><br>0: Keep; 1: SET bit;  |
| 2             |                 | pu_cfg_set_gpio_2  | <b>PAD_GPIO_2</b><br>0: Keep; 1: SET bit;  |
| 1             |                 | pu_cfg_set_gpio_1  | <b>PAD_GPIO_1</b><br>0: Keep; 1: SET bit;  |
| 0             |                 | pu_cfg_set_gpio_0  | <b>PAD_GPIO_0</b><br>0: Keep; 1: SET bit;  |

| <b>A20C0048 PU CFG0 CLR</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>00000000</b> |    |  |  |  |
|-----------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|----|--|--|--|
| <b>Bit</b>                  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17              | 16 |  |  |  |
| <b>Name</b>                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |    |  |  |  |

| Type  |    |    |    |                     |                     |    |   |   |   |   |   |                    |                    |                    |                    |                    |
|-------|----|----|----|---------------------|---------------------|----|---|---|---|---|---|--------------------|--------------------|--------------------|--------------------|--------------------|
| Reset |    |    |    |                     |                     |    |   |   |   |   |   |                    |                    |                    |                    |                    |
| Bit   | 15 | 14 | 13 | 12                  | 11                  | 10 | 9 | 8 | 7 | 6 | 5 | 4                  | 3                  | 2                  | 1                  | 0                  |
| Name  |    |    |    | pu_cf_g_clr_gpio_22 | pu_cf_g_clr_gpio_21 |    |   |   |   |   |   | pu_cf_g_clr_gpio_4 | pu_cf_g_clr_gpio_3 | pu_cf_g_clr_gpio_2 | pu_cf_g_clr_gpio_1 | pu_cf_g_clr_gpio_0 |
| Type  |    |    |    | WO                  | WO                  |    |   |   |   |   |   | WO                 | WO                 | WO                 | WO                 | WO                 |
| Reset |    |    |    | 0                   | 0                   |    |   |   |   |   |   | 0                  | 0                  | 0                  | 0                  | 0                  |

| Bit(s) | Mnemonic | Name               | Description                                 |
|--------|----------|--------------------|---------------------------------------------|
| 12     |          | pu_cfg_clr_gpio_22 | <b>PAD_GPIO_22</b><br>o: Keep; 1: Clear bit |
| 11     |          | pu_cfg_clr_gpio_21 | <b>PAD_GPIO_21</b><br>o: Keep; 1: Clear bit |
| 4      |          | pu_cfg_clr_gpio_4  | <b>PAD_GPIO_4</b><br>o: Keep; 1: Clear bit  |
| 3      |          | pu_cfg_clr_gpio_3  | <b>PAD_GPIO_3</b><br>o: Keep; 1: Clear bit  |
| 2      |          | pu_cfg_clr_gpio_2  | <b>PAD_GPIO_2</b><br>o: Keep; 1: Clear bit  |
| 1      |          | pu_cfg_clr_gpio_1  | <b>PAD_GPIO_1</b><br>o: Keep; 1: Clear bit  |
| 0      |          | pu_cfg_clr_gpio_0  | <b>PAD_GPIO_0</b><br>o: Keep; 1: Clear bit  |

| A20C0050 RDSEL CFG0 |    |    |    |    |    |    | RX delay selection |                   |                   |                  |                  |    |    |    |    |    | oooooooooooo |  |  |
|---------------------|----|----|----|----|----|----|--------------------|-------------------|-------------------|------------------|------------------|----|----|----|----|----|--------------|--|--|
| Bit                 | 31 | 30 | 29 | 28 | 27 | 26 | 25                 | 24                | 23                | 22               | 21               | 20 | 19 | 18 | 17 | 16 |              |  |  |
| Name                |    |    |    |    |    |    |                    | rdsel_cfg_gpio_22 | rdsel_cfg_gpio_21 |                  |                  |    |    |    |    |    |              |  |  |
| Type                |    |    |    |    |    |    |                    | RW                | RW                |                  |                  |    |    |    |    |    |              |  |  |
| Reset               |    |    |    |    |    |    | 0                  | 0                 | 0                 | 0                | 0                | 0  | 0  | 0  | 0  | 0  |              |  |  |
| Bit                 | 15 | 14 | 13 | 12 | 11 | 10 | 9                  | 8                 | 7                 | 6                | 5                | 4  | 3  | 2  | 1  | 0  |              |  |  |
| Name                |    |    |    |    |    |    | rdsel_cfg_gpio_4   | rdsel_cfg_gpio_3  | rdsel_cfg_gpio_2  | rdsel_cfg_gpio_1 | rdsel_cfg_gpio_0 |    |    |    |    |    |              |  |  |
| Type                |    |    |    |    |    |    | RW                 | RW                | RW                | RW               | RW               |    |    |    |    |    |              |  |  |
| Reset               | 0  | 0  | 0  | 0  | 0  | 0  | 0                  | 0                 | 0                 | 0                | 0                | 0  | 0  | 0  | 0  | 0  |              |  |  |

| Bit(s) | Mnemonic | Name              | Description                                                                    |
|--------|----------|-------------------|--------------------------------------------------------------------------------|
| 25:24  |          | rdsel_cfg_gpio_22 | <b>PAD_GPIO_22</b><br>oo: minimum reception delay; 11: maximum reception delay |
| 23:22  |          | rdsel_cfg_gpio_21 | <b>PAD_GPIO_21</b><br>oo: minimum reception delay; 11: maximum reception delay |
| 9:8    |          | rdsel_cfg_gpio_4  | <b>PAD_GPIO_4</b><br>oo: minimum reception delay; 11: maximum reception delay  |

| Bit(s) | Mnemonic         | Name              | Description                                              |
|--------|------------------|-------------------|----------------------------------------------------------|
| 7:6    | rdsel_cfg_gpio_3 | <b>PAD_GPIO_3</b> |                                                          |
|        |                  |                   | 00: minimum reception delay; 11: maximum reception delay |
| 5:4    | rdsel_cfg_gpio_2 | <b>PAD_GPIO_2</b> |                                                          |
|        |                  |                   | 00: minimum reception delay; 11: maximum reception delay |
| 3:2    | rdsel_cfg_gpio_1 | <b>PAD_GPIO_1</b> |                                                          |
|        |                  |                   | 00: minimum reception delay; 11: maximum reception delay |
| 1:0    | rdsel_cfg_gpio_0 | <b>PAD_GPIO_0</b> |                                                          |
|        |                  |                   | 00: minimum reception delay; 11: maximum reception delay |

| <b>A20C0054 RDSEL CFGo SET</b> |    |    |    |    |    |    |                              |    |                              |    |                             | <b>set RDSEL_CFGo</b> |                             |    |                             | <b>00000000</b> |  |  |  |
|--------------------------------|----|----|----|----|----|----|------------------------------|----|------------------------------|----|-----------------------------|-----------------------|-----------------------------|----|-----------------------------|-----------------|--|--|--|
| <b>Bit</b>                     | 31 | 30 | 29 | 28 | 27 | 26 | 25                           | 24 | 23                           | 22 | 21                          | 20                    | 19                          | 18 | 17                          | 16              |  |  |  |
| <b>Name</b>                    |    |    |    |    |    |    | <b>rdsel_cfg_set_gpio_22</b> |    | <b>rdsel_cfg_set_gpio_21</b> |    |                             |                       |                             |    |                             |                 |  |  |  |
| <b>Type</b>                    |    |    |    |    |    |    | WO                           |    | WO                           |    |                             |                       |                             |    |                             |                 |  |  |  |
| <b>Rese t</b>                  |    |    |    |    |    |    | 0                            | 0  | 0                            | 0  |                             |                       |                             |    |                             |                 |  |  |  |
| <b>Bit</b>                     | 15 | 14 | 13 | 12 | 11 | 10 | 9                            | 8  | 7                            | 6  | 5                           | 4                     | 3                           | 2  | 1                           | 0               |  |  |  |
| <b>Name</b>                    |    |    |    |    |    |    | <b>rdsel_cfg_set_gpio_4</b>  |    | <b>rdsel_cfg_set_gpio_3</b>  |    | <b>rdsel_cfg_set_gpio_2</b> |                       | <b>rdsel_cfg_set_gpio_1</b> |    | <b>rdsel_cfg_set_gpio_0</b> |                 |  |  |  |
| <b>Type</b>                    |    |    |    |    |    |    | WO                           |    | WO                           |    | WO                          |                       | WO                          |    | WO                          |                 |  |  |  |
| <b>Rese t</b>                  |    |    |    |    |    |    | 0                            | 0  | 0                            | 0  | 0                           | 0                     | 0                           | 0  | 0                           | 0               |  |  |  |

| Bit(s) | Mnemonic              | Name               | Description          |
|--------|-----------------------|--------------------|----------------------|
| 25:24  | rdsel_cfg_set_gpio_22 | <b>PAD_GPIO_22</b> | 0: Keep; 1: SET bit; |
| 23:22  | rdsel_cfg_set_gpio_21 | <b>PAD_GPIO_21</b> | 0: Keep; 1: SET bit; |
| 9:8    | rdsel_cfg_set_gpio_4  | <b>PAD_GPIO_4</b>  | 0: Keep; 1: SET bit; |
| 7:6    | rdsel_cfg_set_gpio_3  | <b>PAD_GPIO_3</b>  | 0: Keep; 1: SET bit; |
| 5:4    | rdsel_cfg_set_gpio_2  | <b>PAD_GPIO_2</b>  | 0: Keep; 1: SET bit; |

| Bit(s) | Mnemonic | Name                 | Description                               |
|--------|----------|----------------------|-------------------------------------------|
| 3:2    |          | rdsel_cfg_set_gpio_1 | <b>PAD_GPIO_1</b><br>0: Keep; 1: SET bit; |
| 1:0    |          | rdsel_cfg_set_gpio_0 | <b>PAD_GPIO_0</b><br>0: Keep; 1: SET bit; |

| <b>A20C0058 RDSEL_CFGo CLR</b> |    |    |    |    |    |    |                              |                              |                             |                             |                             |    |    |    |    | <b>clear RDSEL_CFGo</b> |     |    |    |    |    |    |    |   |   |   |   |   |   |   |   | <b>oooooooooooo</b> |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|--------------------------------|----|----|----|----|----|----|------------------------------|------------------------------|-----------------------------|-----------------------------|-----------------------------|----|----|----|----|-------------------------|-----|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---------------------|---|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
| Bit                            | 31 | 30 | 29 | 28 | 27 | 26 | 25                           | 24                           | 23                          | 22                          | 21                          | 20 | 19 | 18 | 17 | 16                      | Bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1                   | 0 |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Name</b>                    |    |    |    |    |    |    | <b>rdsel_cfg_clr_gpio_22</b> | <b>rdsel_cfg_clr_gpio_21</b> |                             |                             |                             |    |    |    |    |                         |     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |                     |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>                    |    |    |    |    |    |    | WO                           |                              | WO                          |                             |                             |    |    |    |    |                         |     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |                     |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Reset</b>                   |    |    |    |    |    |    | 0                            | 0                            | 0                           | 0                           |                             |    |    |    |    |                         |     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |                     |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Name</b>                    |    |    |    |    |    |    | <b>rdsel_cfg_clr_gpio_4</b>  | <b>rdsel_cfg_clr_gpio_3</b>  | <b>rdsel_cfg_clr_gpio_2</b> | <b>rdsel_cfg_clr_gpio_1</b> | <b>rdsel_cfg_clr_gpio_0</b> |    |    |    |    |                         |     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |                     |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>                    |    |    |    |    |    |    | WO                           |                              | WO                          |                             | WO                          |    | WO |    | WO |                         |     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |                     |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Reset</b>                   |    |    |    |    |    |    | 0                            | 0                            | 0                           | 0                           | 0                           | 0  | 0  | 0  | 0  |                         |     |    |    |    |    |    |    |   |   |   |   |   |   |   |   |                     |   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bit(s) | Mnemonic | Name                  | Description                                 |
|--------|----------|-----------------------|---------------------------------------------|
| 25:24  |          | rdsel_cfg_clr_gpio_22 | <b>PAD_GPIO_22</b><br>0: Keep; 1: Clear bit |
| 23:22  |          | rdsel_cfg_clr_gpio_21 | <b>PAD_GPIO_21</b><br>0: Keep; 1: Clear bit |
| 9:8    |          | rdsel_cfg_clr_gpio_4  | <b>PAD_GPIO_4</b><br>0: Keep; 1: Clear bit  |
| 7:6    |          | rdsel_cfg_clr_gpio_3  | <b>PAD_GPIO_3</b><br>0: Keep; 1: Clear bit  |
| 5:4    |          | rdsel_cfg_clr_gpio_2  | <b>PAD_GPIO_2</b><br>0: Keep; 1: Clear bit  |
| 3:2    |          | rdsel_cfg_clr_gpio_1  | <b>PAD_GPIO_1</b><br>0: Keep; 1: Clear bit  |
| 1:0    |          | rdsel_cfg_clr_gpio_0  | <b>PAD_GPIO_0</b><br>0: Keep; 1: Clear bit  |

| <b>A20C0060 SMT CFGo</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>oooooooooooo</b> |     |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|--------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------|-----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit                      | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                  | Bit | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |

| Name  |    |    |    |                                          |    |    |   |   |   |   |   |                                                                        |                                     |    |    |    |  |
|-------|----|----|----|------------------------------------------|----|----|---|---|---|---|---|------------------------------------------------------------------------|-------------------------------------|----|----|----|--|
| Type  |    |    |    |                                          |    |    |   |   |   |   |   |                                                                        |                                     |    |    |    |  |
| Reset |    |    |    |                                          |    |    |   |   |   |   |   |                                                                        |                                     |    |    |    |  |
| Bit   | 15 | 14 | 13 | 12                                       | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4                                                                      | 3                                   | 2  | 1  | 0  |  |
| Name  |    |    |    | smt_csmt_c<br>fg_gp fg_gp<br>io_22 io_21 |    |    |   |   |   |   |   | smt_csmt_csmt_csmt_c<br>fg_gp fg_gp fg_gp fg_gp<br>io_4 io_3 io_2 io_1 | smt_csmt_csmt_csmt_c<br>cfg_g pio_o |    |    |    |  |
| Type  |    |    |    | RW                                       | RW |    |   |   |   |   |   | RW                                                                     | RW                                  | RW | RW | RW |  |
| Reset |    |    |    | 0                                        | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0                                                                      | 0                                   | 0  | 0  | 0  |  |

| Bit(s) | Mnemonic | Name            | Description                                  |
|--------|----------|-----------------|----------------------------------------------|
| 12     |          | smt_cfg_gpio_22 | <b>PAD_GPIO_22</b><br>o: Disable; 1: Enable; |
| 11     |          | smt_cfg_gpio_21 | <b>PAD_GPIO_21</b><br>o: Disable; 1: Enable; |
| 4      |          | smt_cfg_gpio_4  | <b>PAD_GPIO_4</b><br>o: Disable; 1: Enable;  |
| 3      |          | smt_cfg_gpio_3  | <b>PAD_GPIO_3</b><br>o: Disable; 1: Enable;  |
| 2      |          | smt_cfg_gpio_2  | <b>PAD_GPIO_2</b><br>o: Disable; 1: Enable;  |
| 1      |          | smt_cfg_gpio_1  | <b>PAD_GPIO_1</b><br>o: Disable; 1: Enable;  |
| 0      |          | smt_cfg_gpio_0  | <b>PAD_GPIO_0</b><br>o: Disable; 1: Enable;  |

| A20C0064 SMT CFG0 SET |    |    |    |                                                      |    |    |    |    |    |    |    |                                                                                            |                                               |    |    |    |  |
|-----------------------|----|----|----|------------------------------------------------------|----|----|----|----|----|----|----|--------------------------------------------------------------------------------------------|-----------------------------------------------|----|----|----|--|
| Bit                   | 31 | 30 | 29 | 28                                                   | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20                                                                                         | 19                                            | 18 | 17 | 16 |  |
| Name                  |    |    |    |                                                      |    |    |    |    |    |    |    |                                                                                            |                                               |    |    |    |  |
| Type                  |    |    |    |                                                      |    |    |    |    |    |    |    |                                                                                            |                                               |    |    |    |  |
| Reset                 |    |    |    |                                                      |    |    |    |    |    |    |    |                                                                                            |                                               |    |    |    |  |
| Bit                   | 15 | 14 | 13 | 12                                                   | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4                                                                                          | 3                                             | 2  | 1  | 0  |  |
| Name                  |    |    |    | smt_csmt_c<br>fg_setfg_set<br>_gpio _gpio<br>_22 _21 |    |    |    |    |    |    |    | smt_csmt_csmt_csmt_c<br>fg_setfg_setfg_setfg_set<br>_gpio _gpio _gpio _gpio<br>_4 _3 _2 _1 | smt_csmt_csmt_csmt_c<br>cfg_s et_gp<br>_io _o |    |    |    |  |
| Type                  |    |    |    | WO                                                   | WO |    |    |    |    |    |    | WO                                                                                         | WO                                            | WO | WO | WO |  |
| Reset                 |    |    |    | 0                                                    | 0  |    |    |    |    |    |    | 0                                                                                          | 0                                             | 0  | 0  | 0  |  |

| Bit(s) | Mnemonic | Name                | Description                                |
|--------|----------|---------------------|--------------------------------------------|
| 12     |          | smt_cfg_set_gpio_22 | <b>PAD_GPIO_22</b><br>o: Keep; 1: SET bit; |
| 11     |          | smt_cfg_set_gpio_21 | <b>PAD_GPIO_21</b><br>o: Keep; 1: SET bit; |
| 4      |          | smt_cfg_set_gpio_4  | <b>PAD_GPIO_4</b><br>o: Keep; 1: SET bit;  |
| 3      |          | smt_cfg_set_gpio_3  | <b>PAD_GPIO_3</b><br>o: Keep; 1: SET bit;  |
| 2      |          | smt_cfg_set_gpio_2  | <b>PAD_GPIO_2</b><br>o: Keep; 1: SET bit;  |
| 1      |          | smt_cfg_set_gpio_1  | <b>PAD_GPIO_1</b><br>o: Keep; 1: SET bit;  |
| 0      |          | smt_cfg_set_gpio_0  | <b>PAD_GPIO_0</b><br>o: Keep; 1: SET bit;  |

| Bit(s) | Mnemonic | Name | Description |
|--------|----------|------|-------------|
|--------|----------|------|-------------|

**A20Coo68 SMT CFG0 CLR** **oooooooooooo**

| Bit   | 31 | 30 | 29                                                | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21                                                                                     | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|---------------------------------------------------|----|----|----|----|----|----|----|----------------------------------------------------------------------------------------|----|----|----|----|----|
| Name  |    |    |                                                   |    |    |    |    |    |    |    |                                                                                        |    |    |    |    |    |
| Type  |    |    |                                                   |    |    |    |    |    |    |    |                                                                                        |    |    |    |    |    |
| Reset |    |    |                                                   |    |    |    |    |    |    |    |                                                                                        |    |    |    |    |    |
| Bit   | 15 | 14 | 13                                                | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5                                                                                      | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    | smt_csmt_c<br>fg_clrfg_clr<br>gpio_gpio<br>_22_21 |    |    |    |    |    |    |    | smt_csmt_csmt_c<br>fg_clrfg_clrfg_clrfg_clr<br>gpio_gpio_gpio_gpio<br>_4_3_2_1<br>_o_o |    |    |    |    |    |
| Type  |    |    | WO                                                |    | WO |    |    |    |    |    | WO                                                                                     |    | WO |    | WO |    |
| Reset |    |    | 0                                                 |    |    |    |    |    |    |    | 0                                                                                      |    | 0  |    | 0  |    |

| Bit(s) | Mnemonic | Name                | Description                                 |
|--------|----------|---------------------|---------------------------------------------|
| 12     |          | smt_cfg_clr_gpio_22 | <b>PAD_GPIO_22</b><br>o: Keep; 1: Clear bit |
| 11     |          | smt_cfg_clr_gpio_21 | <b>PAD_GPIO_21</b><br>o: Keep; 1: Clear bit |
| 4      |          | smt_cfg_clr_gpio_4  | <b>PAD_GPIO_4</b><br>o: Keep; 1: Clear bit  |
| 3      |          | smt_cfg_clr_gpio_3  | <b>PAD_GPIO_3</b><br>o: Keep; 1: Clear bit  |
| 2      |          | smt_cfg_clr_gpio_2  | <b>PAD_GPIO_2</b><br>o: Keep; 1: Clear bit  |
| 1      |          | smt_cfg_clr_gpio_1  | <b>PAD_GPIO_1</b><br>o: Keep; 1: Clear bit  |
| 0      |          | smt_cfg_clr_gpio_0  | <b>PAD_GPIO_0</b><br>o: Keep; 1: Clear bit  |

| Bit   | 31                      | 30 | 29 | 28 | 27                      | 26 | 25 | 24 | 23                      | 22 | 21 | 20 | 19                      | 18 | 17 | 16                      |
|-------|-------------------------|----|----|----|-------------------------|----|----|----|-------------------------|----|----|----|-------------------------|----|----|-------------------------|
| Name  |                         |    |    |    |                         |    |    |    |                         |    |    |    |                         |    |    | <b>tdsel_cfg_gpio_4</b> |
| Type  |                         |    |    |    |                         |    |    |    |                         |    |    |    |                         |    |    | RW                      |
| Reset |                         |    |    |    |                         |    |    |    |                         |    |    |    |                         |    |    | 0                       |
| Bit   | 15                      | 14 | 13 | 12 | 11                      | 10 | 9  | 8  | 7                       | 6  | 5  | 4  | 3                       | 2  | 1  | 0                       |
| Name  | <b>tdsel_cfg_gpio_3</b> |    |    |    | <b>tdsel_cfg_gpio_2</b> |    |    |    | <b>tdsel_cfg_gpio_1</b> |    |    |    | <b>tdsel_cfg_gpio_0</b> |    |    |                         |
| Type  | RW                      |    |    |                         |
| Reset | 1 0 1 0                 |    |    |    | 1 0 1 0                 |    |    |    | 1 0 1 0                 |    |    |    | 1 0 1 0                 |    |    |                         |

| Bit(s) | Mnemonic | Name                    | Description                                                                             |
|--------|----------|-------------------------|-----------------------------------------------------------------------------------------|
| 19:16  |          | <b>tdsel_cfg_gpio_4</b> | <b>PAD_GPIO_4</b><br>oooo: minimum transmission delay; 1111: maximum transmission delay |
| 15:12  |          | <b>tdsel_cfg_gpio_3</b> | <b>PAD_GPIO_3</b><br>oooo: minimum transmission delay; 1111: maximum                    |

| Bit(s) | Mnemonic         | Name              | Description                                                        |
|--------|------------------|-------------------|--------------------------------------------------------------------|
| 11:8   |                  |                   | transmission delay                                                 |
|        | tdsel_cfg_gpio_2 | <b>PAD_GPIO_2</b> |                                                                    |
|        |                  |                   | oooo: minimum transmission delay; 1111: maximum transmission delay |
| 7:4    |                  | tdsel_cfg_gpio_1  | <b>PAD_GPIO_1</b>                                                  |
|        |                  |                   | oooo: minimum transmission delay; 1111: maximum transmission delay |
| 3:0    |                  | tdsel_cfg_gpio_0  | <b>PAD_GPIO_0</b>                                                  |
|        |                  |                   | oooo: minimum transmission delay; 1111: maximum transmission delay |

| <b>A20C0084 TDSEL CFG00 SET set TDSEL_CFG00 00000000</b> |                             |    |    |    |                             |    |    |    |                             |    |    |    |                             |    |    |    |
|----------------------------------------------------------|-----------------------------|----|----|----|-----------------------------|----|----|----|-----------------------------|----|----|----|-----------------------------|----|----|----|
| Bit                                                      | 31                          | 30 | 29 | 28 | 27                          | 26 | 25 | 24 | 23                          | 22 | 21 | 20 | 19                          | 18 | 17 | 16 |
| <b>Name</b>                                              |                             |    |    |    |                             |    |    |    |                             |    |    |    | <b>tdsel_cfg_set_gpio_4</b> |    |    |    |
| <b>Type</b>                                              |                             |    |    |    |                             |    |    |    |                             |    |    |    | WO                          |    |    |    |
| <b>Rese t</b>                                            | 0                           | 0  | 0  | 0  | 0                           | 0  | 0  | 0  | 0                           | 0  | 0  | 0  | 0                           | 0  | 0  |    |
| Bit                                                      | 15                          | 14 | 13 | 12 | 11                          | 10 | 9  | 8  | 7                           | 6  | 5  | 4  | 3                           | 2  | 1  | 0  |
| <b>Name</b>                                              | <b>tdsel_cfg_set_gpio_3</b> |    |    |    | <b>tdsel_cfg_set_gpio_2</b> |    |    |    | <b>tdsel_cfg_set_gpio_1</b> |    |    |    | <b>tdsel_cfg_set_gpio_0</b> |    |    |    |
| <b>Type</b>                                              | WO                          |    |    |    |
| <b>Rese t</b>                                            | 0                           | 0  | 0  | 0  | 0                           | 0  | 0  | 0  | 0                           | 0  | 0  | 0  | 0                           | 0  | 0  |    |

| Bit(s) | Mnemonic | Name                 | Description          |
|--------|----------|----------------------|----------------------|
| 19:16  |          | tdsel_cfg_set_gpio_4 | <b>PAD_GPIO_4</b>    |
|        |          |                      | 0: Keep; 1: SET bit; |
| 15:12  |          | tdsel_cfg_set_gpio_3 | <b>PAD_GPIO_3</b>    |
|        |          |                      | 0: Keep; 1: SET bit; |
| 11:8   |          | tdsel_cfg_set_gpio_2 | <b>PAD_GPIO_2</b>    |
|        |          |                      | 0: Keep; 1: SET bit; |
| 7:4    |          | tdsel_cfg_set_gpio_1 | <b>PAD_GPIO_1</b>    |
|        |          |                      | 0: Keep; 1: SET bit; |
| 3:0    |          | tdsel_cfg_set_gpio_0 | <b>PAD_GPIO_0</b>    |
|        |          |                      | 0: Keep; 1: SET bit; |

**A20C0088 TDSEL CFG00 CLR clear TDSEL\_CFG00 00000000**

|              |                             |    |    |    |                             |    |    |    |                             |    |    |    |                             |    |    |    |
|--------------|-----------------------------|----|----|----|-----------------------------|----|----|----|-----------------------------|----|----|----|-----------------------------|----|----|----|
| <b>Bit</b>   | 31                          | 30 | 29 | 28 | 27                          | 26 | 25 | 24 | 23                          | 22 | 21 | 20 | 19                          | 18 | 17 | 16 |
| <b>Name</b>  |                             |    |    |    |                             |    |    |    |                             |    |    |    | <b>tdsel_cfg_clr_gpio_4</b> |    |    |    |
| <b>Type</b>  |                             |    |    |    |                             |    |    |    |                             |    |    |    | WO                          |    |    |    |
| <b>Reset</b> | 0                           | 0  | 0  | 0  | 0                           | 0  | 0  | 0  | 0                           | 0  | 0  | 0  | 0                           | 0  | 0  | 0  |
| <b>Bit</b>   | 15                          | 14 | 13 | 12 | 11                          | 10 | 9  | 8  | 7                           | 6  | 5  | 4  | 3                           | 2  | 1  | 0  |
| <b>Name</b>  | <b>tdsel_cfg_clr_gpio_3</b> |    |    |    | <b>tdsel_cfg_clr_gpio_2</b> |    |    |    | <b>tdsel_cfg_clr_gpio_1</b> |    |    |    | <b>tdsel_cfg_clr_gpio_0</b> |    |    |    |
| <b>Type</b>  | WO                          |    |    |    |
| <b>Reset</b> | 0                           | 0  | 0  | 0  | 0                           | 0  | 0  | 0  | 0                           | 0  | 0  | 0  | 0                           | 0  | 0  | 0  |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b>                 | <b>Description</b>                         |
|---------------|-----------------|-----------------------------|--------------------------------------------|
| 19:16         |                 | <b>tdsel_cfg_clr_gpio_4</b> | <b>PAD_GPIO_4</b><br>0: Keep; 1: Clear bit |
| 15:12         |                 | <b>tdsel_cfg_clr_gpio_3</b> | <b>PAD_GPIO_3</b><br>0: Keep; 1: Clear bit |
| 11:8          |                 | <b>tdsel_cfg_clr_gpio_2</b> | <b>PAD_GPIO_2</b><br>0: Keep; 1: Clear bit |
| 7:4           |                 | <b>tdsel_cfg_clr_gpio_1</b> | <b>PAD_GPIO_1</b><br>0: Keep; 1: Clear bit |
| 3:0           |                 | <b>tdsel_cfg_clr_gpio_0</b> | <b>PAD_GPIO_0</b><br>0: Keep; 1: Clear bit |

| <b>A20C0090 TDSEL CFG01 TX delay selection oooAAAAA</b> |                          |    |    |    |    |    |    |    |    |    |    |    |                          |    |    |    |
|---------------------------------------------------------|--------------------------|----|----|----|----|----|----|----|----|----|----|----|--------------------------|----|----|----|
| <b>Bit</b>                                              | 31                       | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19                       | 18 | 17 | 16 |
| <b>Name</b>                                             |                          |    |    |    |    |    |    |    |    |    |    |    | <b>tdsel_cfg_gpio_22</b> |    |    |    |
| <b>Type</b>                                             |                          |    |    |    |    |    |    |    |    |    |    |    | RW                       |    |    |    |
| <b>Reset</b>                                            | 1                        | 0  | 1  | 0  | 1  | 0  | 1  | 0  | 1  | 0  | 1  | 0  | 1                        | 0  | 1  | 0  |
| <b>Bit</b>                                              | 15                       | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3                        | 2  | 1  | 0  |
| <b>Name</b>                                             | <b>tdsel_cfg_gpio_21</b> |    |    |    |    |    |    |    |    |    |    |    |                          |    |    |    |
| <b>Type</b>                                             | RW                       |    |    |    |    |    |    |    |    |    |    |    |                          |    |    |    |
| <b>Reset</b>                                            | 1                        | 0  | 1  | 0  | 1  | 0  | 1  | 0  | 1  | 0  | 1  | 0  | 1                        | 0  | 1  | 0  |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b>              | <b>Description</b>                                                                       |
|---------------|-----------------|--------------------------|------------------------------------------------------------------------------------------|
| 19:16         |                 | <b>tdsel_cfg_gpio_22</b> | <b>PAD_GPIO_22</b><br>oooo: minimum transmission delay; 1111: maximum transmission delay |
| 15:12         |                 | <b>tdsel_cfg_gpio_21</b> | <b>PAD_GPIO_21</b>                                                                       |

| Bit(s) | Mnemonic | Name | Description                                                        |
|--------|----------|------|--------------------------------------------------------------------|
|        |          |      | oooo: minimum transmission delay; 1111: maximum transmission delay |

| <b>A20C0094 TDSEL_CFG01_SET set TDSEL_CFG01 00000000</b> |                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |
|----------------------------------------------------------|-----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------|
| Bit                                                      | 31                    | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                    |
| Name                                                     |                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    | tdsel_cfg_set_gpio_22 |
| Type                                                     |                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    | WO                    |
| Rese t                                                   |                       |    |    |    |    |    |    |    |    |    |    |    | 0  | 0  | 0  | 0                     |
| Bit                                                      | 15                    | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                     |
| Name                                                     | tdsel_cfg_set_gpio_21 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |
| Type                                                     | WO                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |
| Rese t                                                   | 0                     | 0  | 0  | 0  |    |    |    |    |    |    |    |    |    |    |    |                       |

| Bit(s) | Mnemonic | Name                              | Description          |
|--------|----------|-----------------------------------|----------------------|
| 19:16  |          | tdsel_cfg_set_gpio_22 PAD_GPIO_22 | o: Keep; 1: SET bit; |
| 15:12  |          | tdsel_cfg_set_gpio_21 PAD_GPIO_21 | o: Keep; 1: SET bit; |
|        |          |                                   |                      |

| <b>A20C0098 TDSEL_CFG01_CLR clear TDSEL_CFG01 00000000</b> |                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |
|------------------------------------------------------------|-----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------|
| Bit                                                        | 31                    | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                    |
| Name                                                       |                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    | tdsel_cfg_clr_gpio_22 |
| Type                                                       |                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    | WO                    |
| Rese t                                                     |                       |    |    |    |    |    |    |    |    |    |    |    | 0  | 0  | 0  | 0                     |
| Bit                                                        | 15                    | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                     |
| Name                                                       | tdsel_cfg_clr_gpio_21 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |
| Type                                                       | WO                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                       |
| Rese t                                                     | 0                     | 0  | 0  | 0  |    |    |    |    |    |    |    |    |    |    |    |                       |

| Bit(s) | Mnemonic | Name                              | Description           |
|--------|----------|-----------------------------------|-----------------------|
| 19:16  |          | tdsel_cfg_clr_gpio_22 PAD_GPIO_22 | o: Keep; 1: Clear bit |
| 15:12  |          | tdsel_cfg_clr_gpio_21 PAD_GPIO_21 | o: Keep; 1: Clear bit |
|        |          |                                   |                       |

**A20Doooo DRV CFG1****oooooooo**

| Bit    | 31 | 30 | 29                  | 28 | 27                  | 26 | 25                  | 24 | 23                  | 22 | 21                  | 20 | 19                  | 18 | 17                  | 16 |
|--------|----|----|---------------------|----|---------------------|----|---------------------|----|---------------------|----|---------------------|----|---------------------|----|---------------------|----|
| Name   |    |    |                     |    |                     |    |                     |    |                     |    |                     |    |                     |    |                     |    |
| Type   |    |    |                     |    |                     |    |                     |    |                     |    |                     |    |                     |    |                     |    |
| Rese t |    |    |                     |    |                     |    |                     |    |                     |    |                     | o  | o                   | o  | o                   | o  |
| Bit    | 15 | 14 | 13                  | 12 | 11                  | 10 | 9                   | 8  | 7                   | 6  | 5                   | 4  | 3                   | 2  | 1                   | 0  |
| Name   |    |    | drv_cfg_g<br>pio_17 |    | drv_cfg_g<br>pio_16 |    | drv_cfg_g<br>pio_15 |    | drv_cfg_g<br>pio_14 |    | drv_cfg_g<br>pio_13 |    | drv_cfg_g<br>pio_12 |    | drv_cfg_g<br>pio_11 |    |
| Type   |    |    | RW                  |    |
| Rese t | o  | o  | o                   | o  | o                   | o  | o                   | o  | o                   | o  | o                   | o  | o                   | o  | o                   | o  |

| Bit(s) | Mnemonic | Name            | Description                                                                  |
|--------|----------|-----------------|------------------------------------------------------------------------------|
| 13:12  |          | drv_cfg_gpio_17 | <b>PAD_GPIO_17</b><br><br>4mA: [00]<br>8mA: [10]<br>12mA: [01]<br>16mA: [11] |
| 11:10  |          | drv_cfg_gpio_16 | <b>PAD_GPIO_16</b><br><br>4mA: [00]<br>8mA: [10]<br>12mA: [01]<br>16mA: [11] |
| 9:8    |          | drv_cfg_gpio_15 | <b>PAD_GPIO_15</b><br><br>4mA: [00]<br>8mA: [10]<br>12mA: [01]<br>16mA: [11] |
| 7:6    |          | drv_cfg_gpio_14 | <b>PAD_GPIO_14</b><br><br>4mA: [00]<br>8mA: [10]<br>12mA: [01]<br>16mA: [11] |
| 5:4    |          | drv_cfg_gpio_13 | <b>PAD_GPIO_13</b><br><br>4mA: [00]<br>8mA: [10]<br>12mA: [01]<br>16mA: [11] |

| Bit(s) | Mnemonic | Name            | Description                                                              |
|--------|----------|-----------------|--------------------------------------------------------------------------|
| 3:2    |          | drv_cfg_gpio_12 | <b>PAD_GPIO_12</b><br>4mA: [00]<br>8mA: [10]<br>12mA: [01]<br>16mA: [11] |
| 1:0    |          | drv_cfg_gpio_11 | <b>PAD_GPIO_11</b><br>4mA: [00]<br>8mA: [10]<br>12mA: [01]<br>16mA: [11] |

| <b>A20D0004 DRV_CFG1_SET</b> |    |    |                                            |                                            |                                            |                                            |                                            |                                            |    |                                            |    |    |    |    |    |    |
|------------------------------|----|----|--------------------------------------------|--------------------------------------------|--------------------------------------------|--------------------------------------------|--------------------------------------------|--------------------------------------------|----|--------------------------------------------|----|----|----|----|----|----|
| Bit                          | 31 | 30 | 29                                         | 28                                         | 27                                         | 26                                         | 25                                         | 24                                         | 23 | 22                                         | 21 | 20 | 19 | 18 | 17 | 16 |
| <b>Name</b>                  |    |    |                                            |                                            |                                            |                                            |                                            |                                            |    |                                            |    |    |    |    |    |    |
| <b>Type</b>                  |    |    |                                            |                                            |                                            |                                            |                                            |                                            |    |                                            |    |    |    |    |    |    |
| <b>Reset</b>                 |    |    |                                            |                                            |                                            |                                            |                                            |                                            |    |                                            |    |    |    |    |    |    |
| Bit                          | 15 | 14 | 13                                         | 12                                         | 11                                         | 10                                         | 9                                          | 8                                          | 7  | 6                                          | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>                  |    |    | <b>drv_cfg_s<br/>et_gpio_1</b><br><b>7</b> | <b>drv_cfg_s<br/>et_gpio_1</b><br><b>6</b> | <b>drv_cfg_s<br/>et_gpio_1</b><br><b>5</b> | <b>drv_cfg_s<br/>et_gpio_1</b><br><b>4</b> | <b>drv_cfg_s<br/>et_gpio_1</b><br><b>3</b> | <b>drv_cfg_s<br/>et_gpio_1</b><br><b>2</b> |    | <b>drv_cfg_s<br/>et_gpio_1</b><br><b>1</b> |    |    |    |    |    |    |
| <b>Type</b>                  |    |    | WO                                         | WO                                         | WO                                         | WO                                         | WO                                         | WO                                         | WO | WO                                         | WO | WO | WO | WO | WO |    |
| <b>Reset</b>                 |    |    | 0                                          | 0                                          | 0                                          | 0                                          | 0                                          | 0                                          | 0  | 0                                          | 0  | 0  | 0  | 0  | 0  |    |

| Bit(s) | Mnemonic | Name                | Description                                |
|--------|----------|---------------------|--------------------------------------------|
| 13:12  |          | drv_cfg_set_gpio_17 | <b>PAD_GPIO_17</b><br>0: Keep; 1: SET bit; |
| 11:10  |          | drv_cfg_set_gpio_16 | <b>PAD_GPIO_16</b><br>0: Keep; 1: SET bit; |
| 9:8    |          | drv_cfg_set_gpio_15 | <b>PAD_GPIO_15</b><br>0: Keep; 1: SET bit; |
| 7:6    |          | drv_cfg_set_gpio_14 | <b>PAD_GPIO_14</b><br>0: Keep; 1: SET bit; |
| 5:4    |          | drv_cfg_set_gpio_13 | <b>PAD_GPIO_13</b><br>0: Keep; 1: SET bit; |
| 3:2    |          | drv_cfg_set_gpio_12 | <b>PAD_GPIO_12</b><br>0: Keep; 1: SET bit; |

| Bit(s) | Mnemonic | Name                | Description                                |
|--------|----------|---------------------|--------------------------------------------|
| 1:0    |          | drv_cfg_set_gpio_11 | <b>PAD_GPIO_11</b><br>0: Keep; 1: SET bit; |

| <b>A20D0008 DRV CFG1 CLR</b> |    |    |                                |          |                                |          |                                |          |                                |          |                                |          |                                |          | <b>00000000</b>                |          |  |  |
|------------------------------|----|----|--------------------------------|----------|--------------------------------|----------|--------------------------------|----------|--------------------------------|----------|--------------------------------|----------|--------------------------------|----------|--------------------------------|----------|--|--|
| Bit                          | 31 | 30 | 29                             | 28       | 27                             | 26       | 25                             | 24       | 23                             | 22       | 21                             | 20       | 19                             | 18       | 17                             | 16       |  |  |
| <b>Name</b>                  |    |    |                                |          |                                |          |                                |          |                                |          |                                |          |                                |          |                                |          |  |  |
| <b>Type</b>                  |    |    |                                |          |                                |          |                                |          |                                |          |                                |          |                                |          |                                |          |  |  |
| <b>Reset</b>                 |    |    |                                |          |                                |          |                                |          |                                |          |                                |          |                                |          |                                |          |  |  |
| <b>Bit</b>                   | 15 | 14 | 13                             | 12       | 11                             | 10       | 9                              | 8        | 7                              | 6        | 5                              | 4        | 3                              | 2        | 1                              | 0        |  |  |
| <b>Name</b>                  |    |    | <b>drv_cfg_c<br/>lr_gpio_1</b> | <b>7</b> | <b>drv_cfg_c<br/>lr_gpio_1</b> | <b>6</b> | <b>drv_cfg_c<br/>lr_gpio_1</b> | <b>5</b> | <b>drv_cfg_c<br/>lr_gpio_1</b> | <b>4</b> | <b>drv_cfg_c<br/>lr_gpio_1</b> | <b>3</b> | <b>drv_cfg_c<br/>lr_gpio_1</b> | <b>2</b> | <b>drv_cfg_c<br/>lr_gpio_1</b> | <b>1</b> |  |  |
| <b>Type</b>                  |    |    | WO                             |          | WO                             |          | WO                             |          | WO                             |          | WO                             |          | WO                             |          | WO                             |          |  |  |
| <b>Reset</b>                 |    |    | 0                              | 0        | 0                              | 0        | 0                              | 0        | 0                              | 0        | 0                              | 0        | 0                              | 0        | 0                              | 0        |  |  |

| Bit(s) | Mnemonic | Name                | Description                                 |
|--------|----------|---------------------|---------------------------------------------|
| 13:12  |          | drv_cfg_clr_gpio_17 | <b>PAD_GPIO_17</b><br>0: Keep; 1: Clear bit |
| 11:10  |          | drv_cfg_clr_gpio_16 | <b>PAD_GPIO_16</b><br>0: Keep; 1: Clear bit |
| 9:8    |          | drv_cfg_clr_gpio_15 | <b>PAD_GPIO_15</b><br>0: Keep; 1: Clear bit |
| 7:6    |          | drv_cfg_clr_gpio_14 | <b>PAD_GPIO_14</b><br>0: Keep; 1: Clear bit |
| 5:4    |          | drv_cfg_clr_gpio_13 | <b>PAD_GPIO_13</b><br>0: Keep; 1: Clear bit |
| 3:2    |          | drv_cfg_clr_gpio_12 | <b>PAD_GPIO_12</b><br>0: Keep; 1: Clear bit |
| 1:0    |          | drv_cfg_clr_gpio_11 | <b>PAD_GPIO_11</b><br>0: Keep; 1: Clear bit |

| <b>A20D0010 G CFG1</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>0000000F</b> |    |  |  |
|------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|----|--|--|
| Bit                    | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17              | 16 |  |  |
| <b>Name</b>            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |    |  |  |
| <b>Type</b>            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |    |  |  |
| <b>Reset</b>           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |    |  |  |
| <b>Bit</b>             | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1               | 0  |  |  |

|       |  |  |  |  |  |  |  |  |  |  |  |   |   |   |                      |
|-------|--|--|--|--|--|--|--|--|--|--|--|---|---|---|----------------------|
| Name  |  |  |  |  |  |  |  |  |  |  |  |   |   |   | <b>g_cfg_gpio_17</b> |
| Type  |  |  |  |  |  |  |  |  |  |  |  |   |   |   | RW                   |
| Reset |  |  |  |  |  |  |  |  |  |  |  | 1 | 1 | 1 | 1                    |

| Bit(s) | Mnemonic | Name                 | Description                                          |
|--------|----------|----------------------|------------------------------------------------------|
| 0      |          | <b>g_cfg_gpio_17</b> | <b>PAD_GPIO_17</b><br>0: Enable AIO; 1: Disable AIO; |

**A20D0014 G CFG1 SET 00000000**

|              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                          |    |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------------|----|
| <b>Bit</b>   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17                       | 16 |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                          |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                          |    |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                          |    |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1                        | 0  |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>g_cfg_set_gpio_17</b> |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                          | WO |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                          | 0  |

| Bit(s) | Mnemonic | Name                     | Description                                |
|--------|----------|--------------------------|--------------------------------------------|
| 0      |          | <b>g_cfg_set_gpio_17</b> | <b>PAD_GPIO_17</b><br>0: Keep; 1: SET bit; |

**A20D0018 G CFG1 CLR 00000000**

|              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                          |    |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------------|----|
| <b>Bit</b>   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17                       | 16 |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                          |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                          |    |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                          |    |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1                        | 0  |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>g_cfg_clr_gpio_17</b> |    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                          | WO |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                          | 0  |

| Bit(s) | Mnemonic | Name                     | Description                                 |
|--------|----------|--------------------------|---------------------------------------------|
| 0      |          | <b>g_cfg_clr_gpio_17</b> | <b>PAD_GPIO_17</b><br>0: Keep; 1: Clear bit |

**A20D0020 IES CFG1 000003FF**

|              |    |    |    |    |    |    |    |    |    |                          |                          |                          |                          |                          |                          |                          |  |
|--------------|----|----|----|----|----|----|----|----|----|--------------------------|--------------------------|--------------------------|--------------------------|--------------------------|--------------------------|--------------------------|--|
| <b>Bit</b>   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22                       | 21                       | 20                       | 19                       | 18                       | 17                       | 16                       |  |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |                          |                          |                          |                          |                          |                          |                          |  |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |                          |                          |                          |                          |                          |                          |                          |  |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |                          |                          |                          |                          |                          |                          |                          |  |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6                        | 5                        | 4                        | 3                        | 2                        | 1                        | 0                        |  |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    | <b>ies_cf_g_gpi_0_17</b> | <b>ies_cf_g_gpi_0_16</b> | <b>ies_cf_g_gpi_0_15</b> | <b>ies_cf_g_gpi_0_14</b> | <b>ies_cf_g_gpi_0_13</b> | <b>ies_cf_g_gpi_0_12</b> | <b>ies_cf_g_gpi_0_11</b> |  |

| Type  |  |  |  |  |  |  |  |  | RW |
|-------|--|--|--|--|--|--|--|--|----|----|----|----|----|----|----|----|
| Reset |  |  |  |  |  |  |  |  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  |

| Bit(s) | Mnemonic | Name            | Description                                  |
|--------|----------|-----------------|----------------------------------------------|
| 6      |          | ies_cfg_gpio_17 | <b>PAD_GPIO_17</b><br>o: Disable; 1: Enable; |
| 5      |          | ies_cfg_gpio_16 | <b>PAD_GPIO_16</b><br>o: Disable; 1: Enable; |
| 4      |          | ies_cfg_gpio_15 | <b>PAD_GPIO_15</b><br>o: Disable; 1: Enable; |
| 3      |          | ies_cfg_gpio_14 | <b>PAD_GPIO_14</b><br>o: Disable; 1: Enable; |
| 2      |          | ies_cfg_gpio_13 | <b>PAD_GPIO_13</b><br>o: Disable; 1: Enable; |
| 1      |          | ies_cfg_gpio_12 | <b>PAD_GPIO_12</b><br>o: Disable; 1: Enable; |
| 0      |          | ies_cfg_gpio_11 | <b>PAD_GPIO_11</b><br>o: Disable; 1: Enable; |

| <b>A20D0024 IES_CFG1_SET</b> |    |    |    |    |    |    |    |    |    |                             |                             |                             |                             |                             |                             | <b>00000000</b>             |  |  |  |
|------------------------------|----|----|----|----|----|----|----|----|----|-----------------------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|-----------------------------|--|--|--|
| Bit                          | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22                          | 21                          | 20                          | 19                          | 18                          | 17                          | 16                          |  |  |  |
| Name                         |    |    |    |    |    |    |    |    |    |                             |                             |                             |                             |                             |                             |                             |  |  |  |
| Type                         |    |    |    |    |    |    |    |    |    |                             |                             |                             |                             |                             |                             |                             |  |  |  |
| Reset                        |    |    |    |    |    |    |    |    |    |                             |                             |                             |                             |                             |                             |                             |  |  |  |
| Bit                          | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6                           | 5                           | 4                           | 3                           | 2                           | 1                           | 0                           |  |  |  |
| Name                         |    |    |    |    |    |    |    |    |    | <b>ies_cf_g_set_gpio_17</b> | <b>ies_cf_g_set_gpio_16</b> | <b>ies_cf_g_set_gpio_15</b> | <b>ies_cf_g_set_gpio_14</b> | <b>ies_cf_g_set_gpio_13</b> | <b>ies_cf_g_set_gpio_12</b> | <b>ies_cf_g_set_gpio_11</b> |  |  |  |
| Type                         |    |    |    |    |    |    |    |    |    | WO                          |  |  |  |
| Reset                        |    |    |    |    |    |    |    |    |    | 0                           | 0                           | 0                           | 0                           | 0                           | 0                           | 0                           |  |  |  |

| Bit(s) | Mnemonic | Name                | Description                                |
|--------|----------|---------------------|--------------------------------------------|
| 6      |          | ies_cfg_set_gpio_17 | <b>PAD_GPIO_17</b><br>o: Keep; 1: SET bit; |
| 5      |          | ies_cfg_set_gpio_16 | <b>PAD_GPIO_16</b><br>o: Keep; 1: SET bit; |
| 4      |          | ies_cfg_set_gpio_15 | <b>PAD_GPIO_15</b><br>o: Keep; 1: SET bit; |
| 3      |          | ies_cfg_set_gpio_14 | <b>PAD_GPIO_14</b><br>o: Keep; 1: SET bit; |
| 2      |          | ies_cfg_set_gpio_13 | <b>PAD_GPIO_13</b><br>o: Keep; 1: SET bit; |
| 1      |          | ies_cfg_set_gpio_12 | <b>PAD_GPIO_12</b><br>o: Keep; 1: SET bit; |
| 0      |          | ies_cfg_set_gpio_11 | <b>PAD_GPIO_11</b><br>o: Keep; 1: SET bit; |

| <b>A20D0028 IES_CFG1_CLR</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>00000000</b> |  |  |  |
|------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------|--|--|--|
| Bit                          | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16              |  |  |  |
| Name                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |  |  |  |
| Type                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |  |  |  |
| Reset                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                 |  |  |  |

| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6                              | 5                              | 4                              | 3                              | 2                              | 1                              | 0                              |
|-------|----|----|----|----|----|----|---|---|---|--------------------------------|--------------------------------|--------------------------------|--------------------------------|--------------------------------|--------------------------------|--------------------------------|
| Name  |    |    |    |    |    |    |   |   |   | ies_cf<br>g_clr<br>gpio<br>_17 | ies_cf<br>g_clr<br>gpio<br>_16 | ies_cf<br>g_clr<br>gpio<br>_15 | ies_cf<br>g_clr<br>gpio<br>_14 | ies_cf<br>g_clr<br>gpio<br>_13 | ies_cf<br>g_clr<br>gpio<br>_12 | ies_cf<br>g_clr<br>gpio<br>_11 |
| Type  |    |    |    |    |    |    |   |   |   | WO                             |
| Reset |    |    |    |    |    |    |   |   |   | 0                              | 0                              | 0                              | 0                              | 0                              | 0                              | 0                              |

| Bit(s) | Mnemonic | Name                | Description                                 |
|--------|----------|---------------------|---------------------------------------------|
| 6      |          | ies_cfg_clr_gpio_17 | <b>PAD_GPIO_17</b><br>o: Keep; 1: Clear bit |
| 5      |          | ies_cfg_clr_gpio_16 | <b>PAD_GPIO_16</b><br>o: Keep; 1: Clear bit |
| 4      |          | ies_cfg_clr_gpio_15 | <b>PAD_GPIO_15</b><br>o: Keep; 1: Clear bit |
| 3      |          | ies_cfg_clr_gpio_14 | <b>PAD_GPIO_14</b><br>o: Keep; 1: Clear bit |
| 2      |          | ies_cfg_clr_gpio_13 | <b>PAD_GPIO_13</b><br>o: Keep; 1: Clear bit |
| 1      |          | ies_cfg_clr_gpio_12 | <b>PAD_GPIO_12</b><br>o: Keep; 1: Clear bit |
| 0      |          | ies_cfg_clr_gpio_11 | <b>PAD_GPIO_11</b><br>o: Keep; 1: Clear bit |

| A20D0030 PD CFG1 |    |    |    |    |    |    |    |    |    |                             |                                |                                       |    |    |    | ooooooooB |                        |  |  |
|------------------|----|----|----|----|----|----|----|----|----|-----------------------------|--------------------------------|---------------------------------------|----|----|----|-----------|------------------------|--|--|
| Bit              | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22                          | 21                             | 20                                    | 19 | 18 | 17 | 16        |                        |  |  |
| Name             |    |    |    |    |    |    |    |    |    |                             |                                |                                       |    |    |    |           |                        |  |  |
| Type             |    |    |    |    |    |    |    |    |    |                             |                                |                                       |    |    |    |           |                        |  |  |
| Reset            |    |    |    |    |    |    |    |    |    |                             |                                |                                       |    |    |    |           |                        |  |  |
| Bit              | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6                           | 5                              | 4                                     | 3  | 2  | 1  | 0         |                        |  |  |
| Name             |    |    |    |    |    |    |    |    |    | pd_cf<br>g_bo<br>nd_rs<br>v | pd_cf<br>g_bo<br>nd_sf<br>_sip | pd_cf<br>g_bo<br>nd_p<br>sram<br>_sip |    |    |    |           | pd_cf<br>g_gpi<br>o_17 |  |  |
| Type             |    |    |    |    |    |    |    |    |    | RW                          | RW                             | RW                                    |    |    |    |           | RW                     |  |  |
| Reset            |    |    |    |    |    |    |    |    |    | 0                           | 0                              | 0                                     | 1  | 0  | 1  | 1         |                        |  |  |

| Bit(s) | Mnemonic | Name                  | Description                                         |
|--------|----------|-----------------------|-----------------------------------------------------|
| 6      |          | pd_cfg_bond_rsv       | <b>PAD_BOND_RSV</b><br>o: Disable; 1: Enable;       |
| 5      |          | pd_cfg_bond_sf_sip    | <b>PAD_BOND_SF_SIP</b><br>o: Disable; 1: Enable;    |
| 4      |          | pd_cfg_bond_psram_sip | <b>PAD_BOND_PSRAM_SIP</b><br>o: Disable; 1: Enable; |
| 0      |          | pd_cfg_gpio_17        | <b>PAD_GPIO_17</b><br>o: Disable; 1: Enable;        |

| A20D0034 PD CFG1 SET |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | oooooooooooo |  |  |  |
|----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------|--|--|--|
| Bit                  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16           |  |  |  |
| Name                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |  |  |  |
| Type                 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |              |  |  |  |

| Reset |    |    |    |    |    |    |   |   |   |                                 |                                       |                                               |   |   |   |                                |  |
|-------|----|----|----|----|----|----|---|---|---|---------------------------------|---------------------------------------|-----------------------------------------------|---|---|---|--------------------------------|--|
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6                               | 5                                     | 4                                             | 3 | 2 | 1 | 0                              |  |
| Name  |    |    |    |    |    |    |   |   |   | pd_cf<br>g_set<br>_bon<br>d_rsv | pd_cf<br>g_set<br>_bon<br>d_sf<br>sip | pd_cf<br>g_set<br>_bon<br>d_psr<br>am_si<br>p |   |   |   | pd_cf<br>g_set<br>_gpio<br>_17 |  |
| Type  |    |    |    |    |    |    |   |   |   | WO                              | WO                                    | WO                                            |   |   |   | WO                             |  |
| Reset |    |    |    |    |    |    |   |   |   | o                               | o                                     | o                                             |   |   |   | o                              |  |

| Bit(s) | Mnemonic | Name                      | Description                                |
|--------|----------|---------------------------|--------------------------------------------|
| 6      |          | pd_cfg_set_bond_rsv       | PAD_BOND_RSV<br>o: Keep; 1: SET bit;       |
| 5      |          | pd_cfg_set_bond_sf_sip    | PAD_BOND_SF_SIP<br>o: Keep; 1: SET bit;    |
| 4      |          | pd_cfg_set_bond_psram_sip | PAD_BOND_PSRAM_SIP<br>o: Keep; 1: SET bit; |
| 0      |          | pd_cfg_set_gpio_17        | PAD_GPIO_17<br>o: Keep; 1: SET bit;        |

| A20D0038 PD_CFG1 CLR |    |    |    |    |    |    |    |    |    |                                 |                                       |                                               |    |    |    | 00000000                       |  |  |  |
|----------------------|----|----|----|----|----|----|----|----|----|---------------------------------|---------------------------------------|-----------------------------------------------|----|----|----|--------------------------------|--|--|--|
| Bit                  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22                              | 21                                    | 20                                            | 19 | 18 | 17 | 16                             |  |  |  |
| Name                 |    |    |    |    |    |    |    |    |    |                                 |                                       |                                               |    |    |    |                                |  |  |  |
| Type                 |    |    |    |    |    |    |    |    |    |                                 |                                       |                                               |    |    |    |                                |  |  |  |
| Reset                |    |    |    |    |    |    |    |    |    |                                 |                                       |                                               |    |    |    |                                |  |  |  |
| Bit                  | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6                               | 5                                     | 4                                             | 3  | 2  | 1  | 0                              |  |  |  |
| Name                 |    |    |    |    |    |    |    |    |    | pd_cf<br>g_clr<br>_bon<br>d_rsv | pd_cf<br>g_clr<br>_bon<br>d_sf<br>sip | pd_cf<br>g_clr<br>_bon<br>d_psr<br>am_si<br>p |    |    |    | pd_cf<br>g_clr<br>_gpio<br>_17 |  |  |  |
| Type                 |    |    |    |    |    |    |    |    |    | WO                              | WO                                    | WO                                            |    |    |    | WO                             |  |  |  |
| Reset                |    |    |    |    |    |    |    |    |    | o                               | o                                     | o                                             |    |    |    | o                              |  |  |  |

| Bit(s) | Mnemonic | Name                      | Description                                 |
|--------|----------|---------------------------|---------------------------------------------|
| 6      |          | pd_cfg_clr_bond_rsv       | PAD_BOND_RSV<br>o: Keep; 1: Clear bit       |
| 5      |          | pd_cfg_clr_bond_sf_sip    | PAD_BOND_SF_SIP<br>o: Keep; 1: Clear bit    |
| 4      |          | pd_cfg_clr_bond_psram_sip | PAD_BOND_PSRAM_SIP<br>o: Keep; 1: Clear bit |
| 0      |          | pd_cfg_clr_gpio_17        | PAD_GPIO_17<br>o: Keep; 1: Clear bit        |

| A20D0040 PUPD_CFG1 |    |    |    |    |    |    |    |    |    |                     |                     |                     |                     |                     |                     | 0000003F            |  |  |  |
|--------------------|----|----|----|----|----|----|----|----|----|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|--|--|--|
| Bit                | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22                  | 21                  | 20                  | 19                  | 18                  | 17                  | 16                  |  |  |  |
| Name               |    |    |    |    |    |    |    |    |    |                     |                     |                     |                     |                     |                     |                     |  |  |  |
| Type               |    |    |    |    |    |    |    |    |    |                     |                     |                     |                     |                     |                     |                     |  |  |  |
| Reset              |    |    |    |    |    |    |    |    |    |                     |                     |                     |                     |                     |                     |                     |  |  |  |
| Bit                | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6                   | 5                   | 4                   | 3                   | 2                   | 1                   | 0                   |  |  |  |
| Name               |    |    |    |    |    |    |    |    |    | pupd<br>cfg<br>gpio |  |  |  |

| Type  |  |  |  |  |  |  |  |  |  | <b>16</b> | <b>15</b> | <b>14</b> | <b>13</b> | <b>12</b> | <b>11</b> |
|-------|--|--|--|--|--|--|--|--|--|-----------|-----------|-----------|-----------|-----------|-----------|
| Reset |  |  |  |  |  |  |  |  |  |           |           |           |           |           |           |
|       |  |  |  |  |  |  |  |  |  | 1         | 1         | 1         | 1         | 1         | 1         |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b>      | <b>Description</b>                              |
|---------------|-----------------|------------------|-------------------------------------------------|
| 5             |                 | pupd_cfg_gpio_16 | <b>PAD_GPIO_16</b><br>o: Pull up; 1: Pull down; |
| 4             |                 | pupd_cfg_gpio_15 | <b>PAD_GPIO_15</b><br>o: Pull up; 1: Pull down; |
| 3             |                 | pupd_cfg_gpio_14 | <b>PAD_GPIO_14</b><br>o: Pull up; 1: Pull down; |
| 2             |                 | pupd_cfg_gpio_13 | <b>PAD_GPIO_13</b><br>o: Pull up; 1: Pull down; |
| 1             |                 | pupd_cfg_gpio_12 | <b>PAD_GPIO_12</b><br>o: Pull up; 1: Pull down; |
| 0             |                 | pupd_cfg_gpio_11 | <b>PAD_GPIO_11</b><br>o: Pull up; 1: Pull down; |

**A20D0044 PUPD\_CFG1\_SET****00000000**

| <b>Bit</b>   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21                         | 20                         | 19                         | 18                         | 17                         | 16                         |
|--------------|----|----|----|----|----|----|----|----|----|----|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |                            |                            |                            |                            |                            |                            |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |                            |                            |                            |                            |                            |                            |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |                            |                            |                            |                            |                            |                            |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5                          | 4                          | 3                          | 2                          | 1                          | 0                          |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    | <b>pupd_cfg_set_gio_16</b> | <b>pupd_cfg_set_gio_15</b> | <b>pupd_cfg_set_gio_14</b> | <b>pupd_cfg_set_gio_13</b> | <b>pupd_cfg_set_gio_12</b> | <b>pupd_cfg_set_gio_11</b> |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    | WO                         | WO                         | WO                         | WO                         | WO                         | WO                         |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    | 0                          | 0                          | 0                          | 0                          | 0                          | 0                          |

**A20D0044 PUPD\_CFG1\_SET****Description**

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b>          | <b>Description</b>                         |
|---------------|-----------------|----------------------|--------------------------------------------|
| 5             |                 | pupd_cfg_set_gpio_16 | <b>PAD_GPIO_16</b><br>o: Keep; 1: SET bit; |
| 4             |                 | pupd_cfg_set_gpio_15 | <b>PAD_GPIO_15</b><br>o: Keep; 1: SET bit; |
| 3             |                 | pupd_cfg_set_gpio_14 | <b>PAD_GPIO_14</b><br>o: Keep; 1: SET bit; |
| 2             |                 | pupd_cfg_set_gpio_13 | <b>PAD_GPIO_13</b><br>o: Keep; 1: SET bit; |
| 1             |                 | pupd_cfg_set_gpio_12 | <b>PAD_GPIO_12</b><br>o: Keep; 1: SET bit; |
| 0             |                 | pupd_cfg_set_gpio_11 | <b>PAD_GPIO_11</b><br>o: Keep; 1: SET bit; |

**A20D0048 PUPD\_CFG1\_CLR****00000000**

| <b>Bit</b>   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21                         | 20                         | 19                         | 18                         | 17                         | 16                         |
|--------------|----|----|----|----|----|----|----|----|----|----|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |                            |                            |                            |                            |                            |                            |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |                            |                            |                            |                            |                            |                            |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |                            |                            |                            |                            |                            |                            |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5                          | 4                          | 3                          | 2                          | 1                          | 0                          |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    | <b>pupd_cfg_clr_gio_16</b> | <b>pupd_cfg_clr_gio_15</b> | <b>pupd_cfg_clr_gio_14</b> | <b>pupd_cfg_clr_gio_13</b> | <b>pupd_cfg_clr_gio_12</b> | <b>pupd_cfg_clr_gio_11</b> |

|       |  |  |  |  |  |  |  |  |  |                     |                     |                     |                     |                     |                     |
|-------|--|--|--|--|--|--|--|--|--|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|
|       |  |  |  |  |  |  |  |  |  | clr_g<br>pio_1<br>6 | clr_g<br>pio_1<br>5 | clr_g<br>pio_1<br>4 | clr_g<br>pio_1<br>3 | clr_g<br>pio_1<br>2 | clr_g<br>pio_1<br>1 |
| Type  |  |  |  |  |  |  |  |  |  | WO                  | WO                  | WO                  | WO                  | WO                  | WO                  |
| Reset |  |  |  |  |  |  |  |  |  | o                   | o                   | o                   | o                   | o                   | o                   |

| Bit(s) | Mnemonic             | Name               | Description           |
|--------|----------------------|--------------------|-----------------------|
| 5      | pupd_cfg_clr_gpio_16 | <b>PAD_GPIO_16</b> | o: Keep; 1: Clear bit |
| 4      | pupd_cfg_clr_gpio_15 | <b>PAD_GPIO_15</b> | o: Keep; 1: Clear bit |
| 3      | pupd_cfg_clr_gpio_14 | <b>PAD_GPIO_14</b> | o: Keep; 1: Clear bit |
| 2      | pupd_cfg_clr_gpio_13 | <b>PAD_GPIO_13</b> | o: Keep; 1: Clear bit |
| 1      | pupd_cfg_clr_gpio_12 | <b>PAD_GPIO_12</b> | o: Keep; 1: Clear bit |
| 0      | pupd_cfg_clr_gpio_11 | <b>PAD_GPIO_11</b> | o: Keep; 1: Clear bit |

| <b>A20D0050 PU CFG1</b> |    |    |    |    |    |    |    |    |    |                             |                                |                                       |    |    |    | <b>000000074</b>       |
|-------------------------|----|----|----|----|----|----|----|----|----|-----------------------------|--------------------------------|---------------------------------------|----|----|----|------------------------|
| Bit                     | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22                          | 21                             | 20                                    | 19 | 18 | 17 | 16                     |
| <b>Name</b>             |    |    |    |    |    |    |    |    |    |                             |                                |                                       |    |    |    |                        |
| <b>Type</b>             |    |    |    |    |    |    |    |    |    |                             |                                |                                       |    |    |    |                        |
| <b>Reset</b>            |    |    |    |    |    |    |    |    |    |                             |                                |                                       |    |    |    |                        |
| Bit                     | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6                           | 5                              | 4                                     | 3  | 2  | 1  | 0                      |
| <b>Name</b>             |    |    |    |    |    |    |    |    |    | pu_cf<br>g_bo<br>nd_rs<br>v | pu_cf<br>g_bo<br>nd_sf<br>_sip | pu_cf<br>g_bo<br>nd_p<br>sram<br>_sip |    |    |    | pu_cf<br>g_gpi<br>o_17 |
| <b>Type</b>             |    |    |    |    |    |    |    |    |    | RW                          | RW                             | RW                                    |    |    |    | RW                     |
| <b>Reset</b>            |    |    |    |    |    |    |    |    |    | 1                           | 1                              | 1                                     | 0  | 1  | 0  | 0                      |

| Bit(s) | Mnemonic              | Name                      | Description            |
|--------|-----------------------|---------------------------|------------------------|
| 6      | pu_cfg_bond_rsv       | <b>PAD_BOND_RSV</b>       | o: Disable; 1: Enable; |
| 5      | pu_cfg_bond_sf_sip    | <b>PAD_BOND_SF_SIP</b>    | o: Disable; 1: Enable; |
| 4      | pu_cfg_bond_psram_sip | <b>PAD_BOND_PSRAM_SIP</b> | o: Disable; 1: Enable; |
| 0      | pu_cfg_gpio_17        | <b>PAD_GPIO_17</b>        | o: Disable; 1: Enable; |

| <b>A20D0054 PU CFG1 SET</b> |    |    |    |    |    |    |    |    |    |                                |                                       |                                |    |    |    | <b>000000000</b>              |
|-----------------------------|----|----|----|----|----|----|----|----|----|--------------------------------|---------------------------------------|--------------------------------|----|----|----|-------------------------------|
| Bit                         | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22                             | 21                                    | 20                             | 19 | 18 | 17 | 16                            |
| <b>Name</b>                 |    |    |    |    |    |    |    |    |    |                                |                                       |                                |    |    |    |                               |
| <b>Type</b>                 |    |    |    |    |    |    |    |    |    |                                |                                       |                                |    |    |    |                               |
| <b>Reset</b>                |    |    |    |    |    |    |    |    |    |                                |                                       |                                |    |    |    |                               |
| Bit                         | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6                              | 5                                     | 4                              | 3  | 2  | 1  | 0                             |
| <b>Name</b>                 |    |    |    |    |    |    |    |    |    | pu_cf<br>g_set<br>bon<br>d_rsv | pu_cf<br>g_set<br>bon<br>d_sf<br>_sip | pu_cf<br>g_set<br>bon<br>d_psr |    |    |    | pu_cf<br>g_set<br>gpio<br>_17 |

| Type  |  |  |  |  |  |  |  |  | WO | WO | WO |  |  |  |  | WO |
|-------|--|--|--|--|--|--|--|--|----|----|----|--|--|--|--|----|
| Reset |  |  |  |  |  |  |  |  | o  | o  | o  |  |  |  |  | o  |

| Bit(s) | Mnemonic | Name                      | Description                                       |
|--------|----------|---------------------------|---------------------------------------------------|
| 6      |          | pu_cfg_set_bond_rsv       | <b>PAD_BOND_RSV</b><br>o: Keep; 1: SET bit;       |
| 5      |          | pu_cfg_set_bond_sf_sip    | <b>PAD_BOND_SF_SIP</b><br>o: Keep; 1: SET bit;    |
| 4      |          | pu_cfg_set_bond_psram_sip | <b>PAD_BOND_PSRAM_SIP</b><br>o: Keep; 1: SET bit; |
| 0      |          | pu_cfg_set_gpio_17        | <b>PAD_GPIO_17</b><br>o: Keep; 1: SET bit;        |

**A20D0058 PU\_CFG1 CLR** **00000000**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22                    | 21                       | 20                            | 19 | 18 | 17 | 16                  |
|-------|----|----|----|----|----|----|----|----|----|-----------------------|--------------------------|-------------------------------|----|----|----|---------------------|
| Name  |    |    |    |    |    |    |    |    |    |                       |                          |                               |    |    |    |                     |
| Type  |    |    |    |    |    |    |    |    |    |                       |                          |                               |    |    |    |                     |
| Reset |    |    |    |    |    |    |    |    |    |                       |                          |                               |    |    |    |                     |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6                     | 5                        | 4                             | 3  | 2  | 1  | 0                   |
| Name  |    |    |    |    |    |    |    |    |    | pu_cf_g_clr_bon_d_rsv | pu_cf_g_clr_bon_d_sf_sip | pu_cf_g_clr_bon_d_psr_am_si_p |    |    |    | pu_cf_g_clr_gpio_17 |
| Type  |    |    |    |    |    |    |    |    |    | WO                    | WO                       | WO                            |    |    |    | WO                  |
| Reset |    |    |    |    |    |    |    |    |    | o                     | o                        | o                             |    |    |    | o                   |

| Bit(s) | Mnemonic | Name                      | Description                                        |
|--------|----------|---------------------------|----------------------------------------------------|
| 6      |          | pu_cfg_clr_bond_rsv       | <b>PAD_BOND_RSV</b><br>o: Keep; 1: Clear bit       |
| 5      |          | pu_cfg_clr_bond_sf_sip    | <b>PAD_BOND_SF_SIP</b><br>o: Keep; 1: Clear bit    |
| 4      |          | pu_cfg_clr_bond_psram_sip | <b>PAD_BOND_PSRAM_SIP</b><br>o: Keep; 1: Clear bit |
| 0      |          | pu_cfg_clr_gpio_17        | <b>PAD_GPIO_17</b><br>o: Keep; 1: Clear bit        |

**A20D0060 RO\_CFG1** **00000000**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22               | 21               | 20               | 19               | 18               | 17               | 16 |
|-------|----|----|----|----|----|----|----|----|----|------------------|------------------|------------------|------------------|------------------|------------------|----|
| Name  |    |    |    |    |    |    |    |    |    |                  |                  |                  |                  |                  |                  |    |
| Type  |    |    |    |    |    |    |    |    |    |                  |                  |                  |                  |                  |                  |    |
| Reset |    |    |    |    |    |    |    |    |    |                  |                  |                  |                  |                  |                  |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6                | 5                | 4                | 3                | 2                | 1                | 0  |
| Name  |    |    |    |    |    |    |    |    |    | ro_cf_g_gpi_o_16 | ro_cf_g_gpi_o_15 | ro_cf_g_gpi_o_14 | ro_cf_g_gpi_o_13 | ro_cf_g_gpi_o_12 | ro_cf_g_gpi_o_11 |    |
| Type  |    |    |    |    |    |    |    |    |    | RW               | RW               | RW               | RW               | RW               | RW               | RW |
| Reset |    |    |    |    |    |    |    |    |    | o                | o                | o                | o                | o                | o                | o  |

| Bit(s) | Mnemonic | Name           | Description        |
|--------|----------|----------------|--------------------|
| 5      |          | ro_cfg_gpio_16 | <b>PAD_GPIO_16</b> |

| Bit(s) | Mnemonic | Name           | Description                                  |
|--------|----------|----------------|----------------------------------------------|
| 4      |          | ro_cfg_gpio_15 | o: Disable; 1: Enable;<br><b>PAD_GPIO_15</b> |
| 3      |          | ro_cfg_gpio_14 | o: Disable; 1: Enable;<br><b>PAD_GPIO_14</b> |
| 2      |          | ro_cfg_gpio_13 | o: Disable; 1: Enable;<br><b>PAD_GPIO_13</b> |
| 1      |          | ro_cfg_gpio_12 | o: Disable; 1: Enable;<br><b>PAD_GPIO_12</b> |
| 0      |          | ro_cfg_gpio_11 | o: Disable; 1: Enable;<br><b>PAD_GPIO_11</b> |

**A20D0064 Ro\_CFG1\_SET 00000000**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21                         | 20                         | 19                         | 18                         | 17                         | 16                         |
|-------|----|----|----|----|----|----|----|----|----|----|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|
| Name  |    |    |    |    |    |    |    |    |    |    |                            |                            |                            |                            |                            |                            |
| Type  |    |    |    |    |    |    |    |    |    |    |                            |                            |                            |                            |                            |                            |
| Reset |    |    |    |    |    |    |    |    |    |    |                            |                            |                            |                            |                            |                            |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5                          | 4                          | 3                          | 2                          | 1                          | 0                          |
| Name  |    |    |    |    |    |    |    |    |    |    | <b>ro_cf_g_set_gpio_16</b> | <b>ro_cf_g_set_gpio_15</b> | <b>ro_cf_g_set_gpio_14</b> | <b>ro_cf_g_set_gpio_13</b> | <b>ro_cf_g_set_gpio_12</b> | <b>ro_cf_g_set_gpio_11</b> |
| Type  |    |    |    |    |    |    |    |    |    |    | WO                         | WO                         | WO                         | WO                         | WO                         | WO                         |
| Reset |    |    |    |    |    |    |    |    |    |    | 0                          | 0                          | 0                          | 0                          | 0                          | 0                          |

| Bit(s) | Mnemonic | Name               | Description                                |
|--------|----------|--------------------|--------------------------------------------|
| 5      |          | ro_cfg_set_gpio_16 | <b>PAD_GPIO_16</b><br>o: Keep; 1: SET bit; |
| 4      |          | ro_cfg_set_gpio_15 | <b>PAD_GPIO_15</b><br>o: Keep; 1: SET bit; |
| 3      |          | ro_cfg_set_gpio_14 | <b>PAD_GPIO_14</b><br>o: Keep; 1: SET bit; |
| 2      |          | ro_cfg_set_gpio_13 | <b>PAD_GPIO_13</b><br>o: Keep; 1: SET bit; |
| 1      |          | ro_cfg_set_gpio_12 | <b>PAD_GPIO_12</b><br>o: Keep; 1: SET bit; |
| 0      |          | ro_cfg_set_gpio_11 | <b>PAD_GPIO_11</b><br>o: Keep; 1: SET bit; |

**A20D0068 Ro\_CFG1\_CLR 00000000**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21                         | 20                         | 19                         | 18                         | 17                         | 16                         |
|-------|----|----|----|----|----|----|----|----|----|----|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|
| Name  |    |    |    |    |    |    |    |    |    |    |                            |                            |                            |                            |                            |                            |
| Type  |    |    |    |    |    |    |    |    |    |    |                            |                            |                            |                            |                            |                            |
| Reset |    |    |    |    |    |    |    |    |    |    |                            |                            |                            |                            |                            |                            |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5                          | 4                          | 3                          | 2                          | 1                          | 0                          |
| Name  |    |    |    |    |    |    |    |    |    |    | <b>ro_cf_g_clr_gpio_16</b> | <b>ro_cf_g_clr_gpio_15</b> | <b>ro_cf_g_clr_gpio_14</b> | <b>ro_cf_g_clr_gpio_13</b> | <b>ro_cf_g_clr_gpio_12</b> | <b>ro_cf_g_clr_gpio_11</b> |
| Type  |    |    |    |    |    |    |    |    |    |    | WO                         | WO                         | WO                         | WO                         | WO                         | WO                         |
| Reset |    |    |    |    |    |    |    |    |    |    | 0                          | 0                          | 0                          | 0                          | 0                          | 0                          |

| Bit(s) | Mnemonic | Name | Description |
|--------|----------|------|-------------|
|        |          |      |             |

| Bit(s) | Mnemonic | Name               | Description                                 |
|--------|----------|--------------------|---------------------------------------------|
| 5      |          | ro_cfg_clr_gpio_16 | <b>PAD_GPIO_16</b><br>o: Keep; 1: Clear bit |
| 4      |          | ro_cfg_clr_gpio_15 | <b>PAD_GPIO_15</b><br>o: Keep; 1: Clear bit |
| 3      |          | ro_cfg_clr_gpio_14 | <b>PAD_GPIO_14</b><br>o: Keep; 1: Clear bit |
| 2      |          | ro_cfg_clr_gpio_13 | <b>PAD_GPIO_13</b><br>o: Keep; 1: Clear bit |
| 1      |          | ro_cfg_clr_gpio_12 | <b>PAD_GPIO_12</b><br>o: Keep; 1: Clear bit |
| 0      |          | ro_cfg_clr_gpio_11 | <b>PAD_GPIO_11</b><br>o: Keep; 1: Clear bit |

**A20D0070 R1 CFG1 0000003F**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21                | 20                | 19                | 18                | 17                | 16                |
|-------|----|----|----|----|----|----|----|----|----|----|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|
| Name  |    |    |    |    |    |    |    |    |    |    |                   |                   |                   |                   |                   |                   |
| Type  |    |    |    |    |    |    |    |    |    |    |                   |                   |                   |                   |                   |                   |
| Reset |    |    |    |    |    |    |    |    |    |    |                   |                   |                   |                   |                   |                   |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5                 | 4                 | 3                 | 2                 | 1                 | 0                 |
| Name  |    |    |    |    |    |    |    |    |    |    | r1_cf_g_gpio_o_16 | r1_cf_g_gpio_o_15 | r1_cf_g_gpio_o_14 | r1_cf_g_gpio_o_13 | r1_cf_g_gpio_o_12 | r1_cf_g_gpio_o_11 |
| Type  |    |    |    |    |    |    |    |    |    |    | RW                | RW                | RW                | RW                | RW                | RW                |
| Reset |    |    |    |    |    |    |    |    |    |    | 1                 | 1                 | 1                 | 1                 | 1                 | 1                 |

| Bit(s) | Mnemonic | Name           | Description                                  |
|--------|----------|----------------|----------------------------------------------|
| 5      |          | r1_cfg_gpio_16 | <b>PAD_GPIO_16</b><br>o: Disable; 1: Enable; |
| 4      |          | r1_cfg_gpio_15 | <b>PAD_GPIO_15</b><br>o: Disable; 1: Enable; |
| 3      |          | r1_cfg_gpio_14 | <b>PAD_GPIO_14</b><br>o: Disable; 1: Enable; |
| 2      |          | r1_cfg_gpio_13 | <b>PAD_GPIO_13</b><br>o: Disable; 1: Enable; |
| 1      |          | r1_cfg_gpio_12 | <b>PAD_GPIO_12</b><br>o: Disable; 1: Enable; |
| 0      |          | r1_cfg_gpio_11 | <b>PAD_GPIO_11</b><br>o: Disable; 1: Enable; |

**A20D0074 R1 CFG1 SET 00000000**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21                    | 20                    | 19                    | 18                    | 17                    | 16                    |
|-------|----|----|----|----|----|----|----|----|----|----|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|
| Name  |    |    |    |    |    |    |    |    |    |    |                       |                       |                       |                       |                       |                       |
| Type  |    |    |    |    |    |    |    |    |    |    |                       |                       |                       |                       |                       |                       |
| Reset |    |    |    |    |    |    |    |    |    |    |                       |                       |                       |                       |                       |                       |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5                     | 4                     | 3                     | 2                     | 1                     | 0                     |
| Name  |    |    |    |    |    |    |    |    |    |    | r1_cf_g_set_gpio_o_16 | r1_cf_g_set_gpio_o_15 | r1_cf_g_set_gpio_o_14 | r1_cf_g_set_gpio_o_13 | r1_cf_g_set_gpio_o_12 | r1_cf_g_set_gpio_o_11 |
| Type  |    |    |    |    |    |    |    |    |    |    | WO                    | WO                    | WO                    | WO                    | WO                    | WO                    |
| Reset |    |    |    |    |    |    |    |    |    |    | 0                     | 0                     | 0                     | 0                     | 0                     | 0                     |

| Bit(s) | Mnemonic | Name | Description |
|--------|----------|------|-------------|
|        |          |      |             |

| Bit(s) | Mnemonic | Name               | Description                                |
|--------|----------|--------------------|--------------------------------------------|
| 5      |          | r1_cfg_set_gpio_16 | <b>PAD_GPIO_16</b><br>o: Keep; 1: SET bit; |
| 4      |          | r1_cfg_set_gpio_15 | <b>PAD_GPIO_15</b><br>o: Keep; 1: SET bit; |
| 3      |          | r1_cfg_set_gpio_14 | <b>PAD_GPIO_14</b><br>o: Keep; 1: SET bit; |
| 2      |          | r1_cfg_set_gpio_13 | <b>PAD_GPIO_13</b><br>o: Keep; 1: SET bit; |
| 1      |          | r1_cfg_set_gpio_12 | <b>PAD_GPIO_12</b><br>o: Keep; 1: SET bit; |
| 0      |          | r1_cfg_set_gpio_11 | <b>PAD_GPIO_11</b><br>o: Keep; 1: SET bit; |

| A20D0078 R1 CFG1 CLR 00000000 |    |    |    |    |    |    |    |    |    |    |                            |                            |                            |                            |                            |                            |
|-------------------------------|----|----|----|----|----|----|----|----|----|----|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|
| Bit                           | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21                         | 20                         | 19                         | 18                         | 17                         | 16                         |
| Name                          |    |    |    |    |    |    |    |    |    |    |                            |                            |                            |                            |                            |                            |
| Type                          |    |    |    |    |    |    |    |    |    |    |                            |                            |                            |                            |                            |                            |
| Reset                         |    |    |    |    |    |    |    |    |    |    |                            |                            |                            |                            |                            |                            |
| Bit                           | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5                          | 4                          | 3                          | 2                          | 1                          | 0                          |
| Name                          |    |    |    |    |    |    |    |    |    |    | <b>r1_cf_g_clr_gpio_16</b> | <b>r1_cf_g_clr_gpio_15</b> | <b>r1_cf_g_clr_gpio_14</b> | <b>r1_cf_g_clr_gpio_13</b> | <b>r1_cf_g_clr_gpio_12</b> | <b>r1_cf_g_clr_gpio_11</b> |
| Type                          |    |    |    |    |    |    |    |    |    |    | WO                         | WO                         | WO                         | WO                         | WO                         | WO                         |
| Reset                         |    |    |    |    |    |    |    |    |    |    | o                          | o                          | o                          | o                          | o                          | o                          |

| Bit(s) | Mnemonic | Name               | Description                                 |
|--------|----------|--------------------|---------------------------------------------|
| 5      |          | r1_cfg_clr_gpio_16 | <b>PAD_GPIO_16</b><br>o: Keep; 1: Clear bit |
| 4      |          | r1_cfg_clr_gpio_15 | <b>PAD_GPIO_15</b><br>o: Keep; 1: Clear bit |
| 3      |          | r1_cfg_clr_gpio_14 | <b>PAD_GPIO_14</b><br>o: Keep; 1: Clear bit |
| 2      |          | r1_cfg_clr_gpio_13 | <b>PAD_GPIO_13</b><br>o: Keep; 1: Clear bit |
| 1      |          | r1_cfg_clr_gpio_12 | <b>PAD_GPIO_12</b><br>o: Keep; 1: Clear bit |
| 0      |          | r1_cfg_clr_gpio_11 | <b>PAD_GPIO_11</b><br>o: Keep; 1: Clear bit |

| A20D0080 RDSEL CFG1 00000000 |    |    |                          |    |                          |    |                          |    |                          |    |                          |    |                          |    |                          |    |
|------------------------------|----|----|--------------------------|----|--------------------------|----|--------------------------|----|--------------------------|----|--------------------------|----|--------------------------|----|--------------------------|----|
| Bit                          | 31 | 30 | 29                       | 28 | 27                       | 26 | 25                       | 24 | 23                       | 22 | 21                       | 20 | 19                       | 18 | 17                       | 16 |
| Name                         |    |    |                          |    |                          |    |                          |    |                          |    |                          |    |                          |    |                          |    |
| Type                         |    |    |                          |    |                          |    |                          |    |                          |    |                          |    |                          |    |                          |    |
| Reset                        |    |    |                          |    |                          |    |                          |    |                          |    |                          |    | o                        | o  | o                        | o  |
| Bit                          | 15 | 14 | 13                       | 12 | 11                       | 10 | 9                        | 8  | 7                        | 6  | 5                        | 4  | 3                        | 2  | 1                        | 0  |
| Name                         |    |    | <b>rdsel_cfg_gpio_17</b> |    | <b>rdsel_cfg_gpio_16</b> |    | <b>rdsel_cfg_gpio_15</b> |    | <b>rdsel_cfg_gpio_14</b> |    | <b>rdsel_cfg_gpio_13</b> |    | <b>rdsel_cfg_gpio_12</b> |    | <b>rdsel_cfg_gpio_11</b> |    |
| Type                         |    |    | RW                       |    |
| Reset                        | o  | o  | o                        | o  | o                        | o  | o                        | o  | o                        | o  | o                        | o  | o                        | o  | o                        |    |

| Bit(s) | Mnemonic          | Name               | Description                                              |
|--------|-------------------|--------------------|----------------------------------------------------------|
| 13:12  | rdsel_cfg_gpio_17 | <b>PAD_GPIO_17</b> | 00: minimum reception delay; 11: maximum reception delay |
| 11:10  | rdsel_cfg_gpio_16 | <b>PAD_GPIO_16</b> | 00: minimum reception delay; 11: maximum reception delay |
| 9:8    | rdsel_cfg_gpio_15 | <b>PAD_GPIO_15</b> | 00: minimum reception delay; 11: maximum reception delay |
| 7:6    | rdsel_cfg_gpio_14 | <b>PAD_GPIO_14</b> | 00: minimum reception delay; 11: maximum reception delay |
| 5:4    | rdsel_cfg_gpio_13 | <b>PAD_GPIO_13</b> | 00: minimum reception delay; 11: maximum reception delay |
| 3:2    | rdsel_cfg_gpio_12 | <b>PAD_GPIO_12</b> | 00: minimum reception delay; 11: maximum reception delay |
| 1:0    | rdsel_cfg_gpio_11 | <b>PAD_GPIO_11</b> | 00: minimum reception delay; 11: maximum reception delay |

| <b>A20D0084 RDSEL CFG1 SET</b> |    |    |                              |                              |                              |                              |                              |                              |                              |    |    |    |    |    |    | <b>oooooooooooo</b> |  |
|--------------------------------|----|----|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|----|----|----|----|----|----|---------------------|--|
| Bit                            | 31 | 30 | 29                           | 28                           | 27                           | 26                           | 25                           | 24                           | 23                           | 22 | 21 | 20 | 19 | 18 | 17 | 16                  |  |
| <b>Name</b>                    |    |    |                              |                              |                              |                              |                              |                              |                              |    |    |    |    |    |    |                     |  |
| <b>Type</b>                    |    |    |                              |                              |                              |                              |                              |                              |                              |    |    |    |    |    |    |                     |  |
| <b>Rese t</b>                  |    |    |                              |                              |                              |                              |                              |                              |                              |    |    |    |    |    |    |                     |  |
| Bit                            | 15 | 14 | 13                           | 12                           | 11                           | 10                           | 9                            | 8                            | 7                            | 6  | 5  | 4  | 3  | 2  | 1  | 0                   |  |
| <b>Name</b>                    |    |    | <b>rdsel_cfg_set_gpio_17</b> | <b>rdsel_cfg_set_gpio_16</b> | <b>rdsel_cfg_set_gpio_15</b> | <b>rdsel_cfg_set_gpio_14</b> | <b>rdsel_cfg_set_gpio_13</b> | <b>rdsel_cfg_set_gpio_12</b> | <b>rdsel_cfg_set_gpio_11</b> |    |    |    |    |    |    |                     |  |
| <b>Type</b>                    |    |    | WO                           | WO | WO | WO | WO | WO | WO |                     |  |
| <b>Rese t</b>                  |    |    | 0                            | 0                            | 0                            | 0                            | 0                            | 0                            | 0                            | 0  | 0  | 0  | 0  | 0  | 0  | 0                   |  |

| Bit(s) | Mnemonic              | Name               | Description          |
|--------|-----------------------|--------------------|----------------------|
| 13:12  | rdsel_cfg_set_gpio_17 | <b>PAD_GPIO_17</b> | 0: Keep; 1: SET bit; |
| 11:10  | rdsel_cfg_set_gpio_16 | <b>PAD_GPIO_16</b> | 0: Keep; 1: SET bit; |

| Bit(s) | Mnemonic | Name                  | Description                                |
|--------|----------|-----------------------|--------------------------------------------|
| 9:8    |          | rdsel_cfg_set_gpio_15 | <b>PAD_GPIO_15</b><br>o: Keep; 1: SET bit; |
| 7:6    |          | rdsel_cfg_set_gpio_14 | <b>PAD_GPIO_14</b><br>o: Keep; 1: SET bit; |
| 5:4    |          | rdsel_cfg_set_gpio_13 | <b>PAD_GPIO_13</b><br>o: Keep; 1: SET bit; |
| 3:2    |          | rdsel_cfg_set_gpio_12 | <b>PAD_GPIO_12</b><br>o: Keep; 1: SET bit; |
| 1:0    |          | rdsel_cfg_set_gpio_11 | <b>PAD_GPIO_11</b><br>o: Keep; 1: SET bit; |

| <b>A20D0088 RDSEL_CFG1 CLR</b> |    |    |                              |                              |                              |                              |                              |                              |                              |    |    |    |    |    |    | <b>oooooooooooo</b> |  |
|--------------------------------|----|----|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|------------------------------|----|----|----|----|----|----|---------------------|--|
| Bit                            | 31 | 30 | 29                           | 28                           | 27                           | 26                           | 25                           | 24                           | 23                           | 22 | 21 | 20 | 19 | 18 | 17 | 16                  |  |
| <b>Name</b>                    |    |    |                              |                              |                              |                              |                              |                              |                              |    |    |    |    |    |    |                     |  |
| <b>Type</b>                    |    |    |                              |                              |                              |                              |                              |                              |                              |    |    |    |    |    |    |                     |  |
| <b>Reset</b>                   |    |    |                              |                              |                              |                              |                              |                              |                              |    |    |    |    |    |    |                     |  |
| Bit                            | 15 | 14 | 13                           | 12                           | 11                           | 10                           | 9                            | 8                            | 7                            | 6  | 5  | 4  | 3  | 2  | 1  | 0                   |  |
| <b>Name</b>                    |    |    | <b>rdsel_cfg_clr_gpio_17</b> | <b>rdsel_cfg_clr_gpio_16</b> | <b>rdsel_cfg_clr_gpio_15</b> | <b>rdsel_cfg_clr_gpio_14</b> | <b>rdsel_cfg_clr_gpio_13</b> | <b>rdsel_cfg_clr_gpio_12</b> | <b>rdsel_cfg_clr_gpio_11</b> |    |    |    |    |    |    |                     |  |
| <b>Type</b>                    |    |    | WO                           | WO | WO | WO | WO | WO | WO |                     |  |
| <b>Reset</b>                   |    |    | 0                            | 0                            | 0                            | 0                            | 0                            | 0                            | 0                            | 0  | 0  | 0  | 0  | 0  | 0  | 0                   |  |

| Bit(s) | Mnemonic | Name                  | Description                                 |
|--------|----------|-----------------------|---------------------------------------------|
| 13:12  |          | rdsel_cfg_clr_gpio_17 | <b>PAD_GPIO_17</b><br>o: Keep; 1: Clear bit |
| 11:10  |          | rdsel_cfg_clr_gpio_16 | <b>PAD_GPIO_16</b><br>o: Keep; 1: Clear bit |
| 9:8    |          | rdsel_cfg_clr_gpio_15 | <b>PAD_GPIO_15</b><br>o: Keep; 1: Clear bit |
| 7:6    |          | rdsel_cfg_clr_gpio_14 | <b>PAD_GPIO_14</b><br>o: Keep; 1: Clear bit |
| 5:4    |          | rdsel_cfg_clr_gpio_13 | <b>PAD_GPIO_13</b><br>o: Keep; 1: Clear bit |
| 3:2    |          | rdsel_cfg_clr_gpio_12 | <b>PAD_GPIO_12</b>                          |

| Bit(s) | Mnemonic              | Name               | Description           |
|--------|-----------------------|--------------------|-----------------------|
| 1:0    | rdsel_cfg_clr_gpio_11 | <b>PAD_GPIO_11</b> | o: Keep; 1: Clear bit |
|        |                       |                    | o: Keep; 1: Clear bit |
|        |                       |                    |                       |

**A20D0090 SMT CFG1** **00000000**

| Bit   | 31 | 30 | 29 | 28                           | 27                             | 26                                     | 25 | 24 | 23 | 22                      | 21                      | 20                      | 19                      | 18                      | 17                      | 16                      |
|-------|----|----|----|------------------------------|--------------------------------|----------------------------------------|----|----|----|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|-------------------------|
| Name  |    |    |    |                              |                                |                                        |    |    |    |                         |                         |                         |                         |                         |                         |                         |
| Type  |    |    |    |                              |                                |                                        |    |    |    |                         |                         |                         |                         |                         |                         |                         |
| Reset |    |    |    |                              |                                |                                        |    |    |    |                         |                         |                         |                         |                         |                         |                         |
| Bit   | 15 | 14 | 13 | 12                           | 11                             | 10                                     | 9  | 8  | 7  | 6                       | 5                       | 4                       | 3                       | 2                       | 1                       | 0                       |
| Name  |    |    |    | smt_c<br>fg_bo<br>nd_rs<br>v | smt_c<br>fg_bo<br>nd_sf<br>sip | smt_c<br>fg_bo<br>nd_p<br>sram<br>_sip |    |    |    | smt_c<br>fg_gp<br>io_17 | smt_c<br>fg_gp<br>io_16 | smt_c<br>fg_gp<br>io_15 | smt_c<br>fg_gp<br>io_14 | smt_c<br>fg_gp<br>io_13 | smt_c<br>fg_gp<br>io_12 | smt_c<br>cfg_g<br>pio_1 |
| Type  |    |    |    | RW                           | RW                             | RW                                     |    |    |    | RW                      |
| Reset |    |    |    | 0                            | 0                              | 0                                      | 0  | 0  | 0  | 0                       | 0                       | 0                       | 0                       | 0                       | 0                       | 0                       |

| Bit(s) | Mnemonic | Name                   | Description               |
|--------|----------|------------------------|---------------------------|
| 12     |          | smt_cfg_bond_rsv       | <b>PAD_BOND_RSV</b>       |
|        |          |                        | o: Disable; 1: Enable;    |
| 11     |          | smt_cfg_bond_sf_sip    | <b>PAD_BOND_SF_SIP</b>    |
|        |          |                        | o: Disable; 1: Enable;    |
| 10     |          | smt_cfg_bond_psram_sip | <b>PAD_BOND_PSRAM_SIP</b> |
|        |          |                        | o: Disable; 1: Enable;    |
| 6      |          | smt_cfg_gpio_17        | <b>PAD_GPIO_17</b>        |
|        |          |                        | o: Disable; 1: Enable;    |
| 5      |          | smt_cfg_gpio_16        | <b>PAD_GPIO_16</b>        |
|        |          |                        | o: Disable; 1: Enable;    |
| 4      |          | smt_cfg_gpio_15        | <b>PAD_GPIO_15</b>        |
|        |          |                        | o: Disable; 1: Enable;    |
| 3      |          | smt_cfg_gpio_14        | <b>PAD_GPIO_14</b>        |
|        |          |                        | o: Disable; 1: Enable;    |
| 2      |          | smt_cfg_gpio_13        | <b>PAD_GPIO_13</b>        |
|        |          |                        | o: Disable; 1: Enable;    |
| 1      |          | smt_cfg_gpio_12        | <b>PAD_GPIO_12</b>        |
|        |          |                        | o: Disable; 1: Enable;    |
| 0      |          | smt_cfg_gpio_11        | <b>PAD_GPIO_11</b>        |
|        |          |                        | o: Disable; 1: Enable;    |

**A20D0094 SMT CFG1 SET** **00000000**

| Bit   | 31 | 30 | 29 | 28                              | 27                             | 26                              | 25 | 24 | 23 | 22                         | 21                         | 20                         | 19                         | 18                         | 17                         | 16                               |
|-------|----|----|----|---------------------------------|--------------------------------|---------------------------------|----|----|----|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------|----------------------------------|
| Name  |    |    |    |                                 |                                |                                 |    |    |    |                            |                            |                            |                            |                            |                            |                                  |
| Type  |    |    |    |                                 |                                |                                 |    |    |    |                            |                            |                            |                            |                            |                            |                                  |
| Reset |    |    |    |                                 |                                |                                 |    |    |    |                            |                            |                            |                            |                            |                            |                                  |
| Bit   | 15 | 14 | 13 | 12                              | 11                             | 10                              | 9  | 8  | 7  | 6                          | 5                          | 4                          | 3                          | 2                          | 1                          | 0                                |
| Name  |    |    |    | smt_c<br>fg_set<br>bon<br>d_rsv | smt_c<br>fg_set<br>bon<br>d_sf | smt_c<br>fg_set<br>bon<br>d_psr |    |    |    | smt_c<br>fg_set<br>gpio_17 | smt_c<br>fg_set<br>gpio_16 | smt_c<br>fg_set<br>gpio_15 | smt_c<br>fg_set<br>gpio_14 | smt_c<br>fg_set<br>gpio_13 | smt_c<br>fg_set<br>gpio_12 | smt_c<br>cfg_s<br>et_gp<br>io_11 |

|       |  |  |  |    |    |    |   |  |  |  |  |    |    |    |    |    |    |    |    |    |    |
|-------|--|--|--|----|----|----|---|--|--|--|--|----|----|----|----|----|----|----|----|----|----|
| Type  |  |  |  | WO | WO | WO | p |  |  |  |  | WO |
| Reset |  |  |  | o  | o  | o  |   |  |  |  |  | o  | o  | o  | o  | o  | o  | o  | o  | o  | o  |

| Bit(s) | Mnemonic | Name                       | Description                                       |
|--------|----------|----------------------------|---------------------------------------------------|
| 12     |          | smt_cfg_set_bond_rsv       | <b>PAD_BOND_RSV</b><br>o: Keep; 1: SET bit;       |
| 11     |          | smt_cfg_set_bond_sf_sip    | <b>PAD_BOND_SF_SIP</b><br>o: Keep; 1: SET bit;    |
| 10     |          | smt_cfg_set_bond_psram_sip | <b>PAD_BOND_PSRAM_SIP</b><br>o: Keep; 1: SET bit; |
| 6      |          | smt_cfg_set_gpio_17        | <b>PAD_GPIO_17</b><br>o: Keep; 1: SET bit;        |
| 5      |          | smt_cfg_set_gpio_16        | <b>PAD_GPIO_16</b><br>o: Keep; 1: SET bit;        |
| 4      |          | smt_cfg_set_gpio_15        | <b>PAD_GPIO_15</b><br>o: Keep; 1: SET bit;        |
| 3      |          | smt_cfg_set_gpio_14        | <b>PAD_GPIO_14</b><br>o: Keep; 1: SET bit;        |
| 2      |          | smt_cfg_set_gpio_13        | <b>PAD_GPIO_13</b><br>o: Keep; 1: SET bit;        |
| 1      |          | smt_cfg_set_gpio_12        | <b>PAD_GPIO_12</b><br>o: Keep; 1: SET bit;        |
| 0      |          | smt_cfg_set_gpio_11        | <b>PAD_GPIO_11</b><br>o: Keep; 1: SET bit;        |

| A20D0098 SMT CFG1 CLR |    |    |    |                        |                           |                                |    |    |    |                      |                      |                      |                      |                      |                      | 00000000             |  |  |  |  |  |
|-----------------------|----|----|----|------------------------|---------------------------|--------------------------------|----|----|----|----------------------|----------------------|----------------------|----------------------|----------------------|----------------------|----------------------|--|--|--|--|--|
| Bit                   | 31 | 30 | 29 | 28                     | 27                        | 26                             | 25 | 24 | 23 | 22                   | 21                   | 20                   | 19                   | 18                   | 17                   | 16                   |  |  |  |  |  |
| Name                  |    |    |    |                        |                           |                                |    |    |    |                      |                      |                      |                      |                      |                      |                      |  |  |  |  |  |
| Type                  |    |    |    |                        |                           |                                |    |    |    |                      |                      |                      |                      |                      |                      |                      |  |  |  |  |  |
| Reset                 |    |    |    |                        |                           |                                |    |    |    |                      |                      |                      |                      |                      |                      |                      |  |  |  |  |  |
| Bit                   | 15 | 14 | 13 | 12                     | 11                        | 10                             | 9  | 8  | 7  | 6                    | 5                    | 4                    | 3                    | 2                    | 1                    | 0                    |  |  |  |  |  |
| Name                  |    |    |    | smt_c_fg_clr_bon_d_rsv | smt_c_fg_clr_bon_d_sf_sip | smt_c_fg_clr_bon_d_psr_am_si_p |    |    |    | smt_c_fg_clr_gpio_17 | smt_c_fg_clr_gpio_16 | smt_c_fg_clr_gpio_15 | smt_c_fg_clr_gpio_14 | smt_c_fg_clr_gpio_13 | smt_c_fg_clr_gpio_12 | smt_c_fg_clr_gpio_11 |  |  |  |  |  |
| Type                  |    |    |    | WO                     | WO                        | WO                             |    |    |    | WO                   |  |  |  |  |  |
| Reset                 |    |    |    | o                      | o                         | o                              |    |    |    | o                    | o                    | o                    | o                    | o                    | o                    | o                    |  |  |  |  |  |

| Bit(s) | Mnemonic | Name                       | Description                                        |
|--------|----------|----------------------------|----------------------------------------------------|
| 12     |          | smt_cfg_clr_bond_rsv       | <b>PAD_BOND_RSV</b><br>o: Keep; 1: Clear bit       |
| 11     |          | smt_cfg_clr_bond_sf_sip    | <b>PAD_BOND_SF_SIP</b><br>o: Keep; 1: Clear bit    |
| 10     |          | smt_cfg_clr_bond_psram_sip | <b>PAD_BOND_PSRAM_SIP</b><br>o: Keep; 1: Clear bit |
| 6      |          | smt_cfg_clr_gpio_17        | <b>PAD_GPIO_17</b><br>o: Keep; 1: Clear bit        |
| 5      |          | smt_cfg_clr_gpio_16        | <b>PAD_GPIO_16</b><br>o: Keep; 1: Clear bit        |
| 4      |          | smt_cfg_clr_gpio_15        | <b>PAD_GPIO_15</b><br>o: Keep; 1: Clear bit        |
| 3      |          | smt_cfg_clr_gpio_14        | <b>PAD_GPIO_14</b><br>o: Keep; 1: Clear bit        |

| Bit(s) | Mnemonic | Name                | Description                                 |
|--------|----------|---------------------|---------------------------------------------|
| 2      |          | smt_cfg_clr_gpio_13 | o: Keep; 1: Clear bit<br><b>PAD_GPIO_13</b> |
| 1      |          | smt_cfg_clr_gpio_12 | o: Keep; 1: Clear bit<br><b>PAD_GPIO_12</b> |
| 0      |          | smt_cfg_clr_gpio_11 | o: Keep; 1: Clear bit<br><b>PAD_GPIO_11</b> |
|        |          |                     | o: Keep; 1: Clear bit                       |

| <b>A20D00Bo TDSEL CFG10</b> |                          |    |    |    |                          |    |    |    |                          |    |    |    |                          |    |    | AAAAAAA |  |  |  |
|-----------------------------|--------------------------|----|----|----|--------------------------|----|----|----|--------------------------|----|----|----|--------------------------|----|----|---------|--|--|--|
| Bit                         | 31                       | 30 | 29 | 28 | 27                       | 26 | 25 | 24 | 23                       | 22 | 21 | 20 | 19                       | 18 | 17 | 16      |  |  |  |
| <b>Name</b>                 |                          |    |    |    | <b>tdsel_cfg_gpio_17</b> |    |    |    | <b>tdsel_cfg_gpio_16</b> |    |    |    | <b>tdsel_cfg_gpio_15</b> |    |    |         |  |  |  |
| <b>Type</b>                 |                          |    |    |    | RW                       |    |    |    | RW                       |    |    |    | RW                       |    |    |         |  |  |  |
| <b>Reset</b>                | 1                        | 0  | 1  | 0  | 1                        | 0  | 1  | 0  | 1                        | 0  | 1  | 0  | 1                        | 0  | 1  | 0       |  |  |  |
| <b>Bit</b>                  | 15                       | 14 | 13 | 12 | 11                       | 10 | 9  | 8  | 7                        | 6  | 5  | 4  | 3                        | 2  | 1  | 0       |  |  |  |
| <b>Name</b>                 | <b>tdsel_cfg_gpio_14</b> |    |    |    | <b>tdsel_cfg_gpio_13</b> |    |    |    | <b>tdsel_cfg_gpio_12</b> |    |    |    | <b>tdsel_cfg_gpio_11</b> |    |    |         |  |  |  |
| <b>Type</b>                 | RW                       |    |    |         |  |  |  |
| <b>Reset</b>                | 1                        | 0  | 1  | 0  | 1                        | 0  | 1  | 0  | 1                        | 0  | 1  | 0  | 1                        | 0  | 1  | 0       |  |  |  |

| Bit(s) | Mnemonic | Name                     | Description                                                                              |
|--------|----------|--------------------------|------------------------------------------------------------------------------------------|
| 27:24  |          | <b>tdsel_cfg_gpio_17</b> | <b>PAD_GPIO_17</b><br>oooo: minimum transmission delay; 1111: maximum transmission delay |
| 23:20  |          | <b>tdsel_cfg_gpio_16</b> | <b>PAD_GPIO_16</b><br>oooo: minimum transmission delay; 1111: maximum transmission delay |
| 19:16  |          | <b>tdsel_cfg_gpio_15</b> | <b>PAD_GPIO_15</b><br>oooo: minimum transmission delay; 1111: maximum transmission delay |
| 15:12  |          | <b>tdsel_cfg_gpio_14</b> | <b>PAD_GPIO_14</b><br>oooo: minimum transmission delay; 1111: maximum transmission delay |
| 11:8   |          | <b>tdsel_cfg_gpio_13</b> | <b>PAD_GPIO_13</b><br>oooo: minimum transmission delay; 1111: maximum transmission delay |
| 7:4    |          | <b>tdsel_cfg_gpio_12</b> | <b>PAD_GPIO_12</b><br>oooo: minimum transmission delay; 1111: maximum transmission delay |
| 3:0    |          | <b>tdsel_cfg_gpio_11</b> | <b>PAD_GPIO_11</b><br>oooo: minimum transmission delay; 1111: maximum transmission delay |

**A2oDooB4 TDSEL\_CFG10\_SET**

oooooooooooo

| Bit          | 31                    | 30 | 29 | 28 | 27                    | 26 | 25 | 24 | 23                    | 22 | 21 | 20 | 19                    | 18 | 17 | 16 |
|--------------|-----------------------|----|----|----|-----------------------|----|----|----|-----------------------|----|----|----|-----------------------|----|----|----|
| <b>Name</b>  |                       |    |    |    | tdsel_cfg_set_gpio_17 |    |    |    | tdsel_cfg_set_gpio_16 |    |    |    | tdsel_cfg_set_gpio_15 |    |    |    |
| <b>Type</b>  |                       |    |    |    | WO                    |    |    |    | WO                    |    |    |    | WO                    |    |    |    |
| <b>Reset</b> |                       |    |    |    | 0                     | 0  | 0  | 0  | 0                     | 0  | 0  | 0  | 0                     | 0  | 0  | 0  |
| <b>Bit</b>   | 15                    | 14 | 13 | 12 | 11                    | 10 | 9  | 8  | 7                     | 6  | 5  | 4  | 3                     | 2  | 1  | 0  |
| <b>Name</b>  | tdsel_cfg_set_gpio_14 |    |    |    | tdsel_cfg_set_gpio_13 |    |    |    | tdsel_cfg_set_gpio_12 |    |    |    | tdsel_cfg_set_gpio_11 |    |    |    |
| <b>Type</b>  | WO                    |    |    |    |
| <b>Reset</b> | 0                     | 0  | 0  | 0  | 0                     | 0  | 0  | 0  | 0                     | 0  | 0  | 0  | 0                     | 0  | 0  | 0  |

**A2oDooB4 TDSEL\_CFG10\_SET**

oooooooooooo

| Bit(s) | Mnemonic | Name                  | Description          |
|--------|----------|-----------------------|----------------------|
| 27:24  |          | tdsel_cfg_set_gpio_17 | <b>PAD_GPIO_17</b>   |
|        |          |                       | 0: Keep; 1: SET bit; |
| 23:20  |          | tdsel_cfg_set_gpio_16 | <b>PAD_GPIO_16</b>   |
|        |          |                       | 0: Keep; 1: SET bit; |
| 19:16  |          | tdsel_cfg_set_gpio_15 | <b>PAD_GPIO_15</b>   |
|        |          |                       | 0: Keep; 1: SET bit; |
| 15:12  |          | tdsel_cfg_set_gpio_14 | <b>PAD_GPIO_14</b>   |
|        |          |                       | 0: Keep; 1: SET bit; |
| 11:8   |          | tdsel_cfg_set_gpio_13 | <b>PAD_GPIO_13</b>   |
|        |          |                       | 0: Keep; 1: SET bit; |
| 7:4    |          | tdsel_cfg_set_gpio_12 | <b>PAD_GPIO_12</b>   |
|        |          |                       | 0: Keep; 1: SET bit; |
| 3:0    |          | tdsel_cfg_set_gpio_11 | <b>PAD_GPIO_11</b>   |
|        |          |                       | 0: Keep; 1: SET bit; |

**A2oDooB8 TDSEL\_CFG10\_CLR**

oooooooooooo

| Bit          | 31                    | 30 | 29 | 28 | 27                    | 26 | 25 | 24 | 23                    | 22 | 21 | 20 | 19                    | 18 | 17 | 16 |
|--------------|-----------------------|----|----|----|-----------------------|----|----|----|-----------------------|----|----|----|-----------------------|----|----|----|
| <b>Name</b>  |                       |    |    |    | tdsel_cfg_clr_gpio_17 |    |    |    | tdsel_cfg_clr_gpio_16 |    |    |    | tdsel_cfg_clr_gpio_15 |    |    |    |
| <b>Type</b>  |                       |    |    |    | WO                    |    |    |    | WO                    |    |    |    | WO                    |    |    |    |
| <b>Reset</b> |                       |    |    |    | 0                     | 0  | 0  | 0  | 0                     | 0  | 0  | 0  | 0                     | 0  | 0  | 0  |
| <b>Bit</b>   | 15                    | 14 | 13 | 12 | 11                    | 10 | 9  | 8  | 7                     | 6  | 5  | 4  | 3                     | 2  | 1  | 0  |
| <b>Name</b>  | tdsel_cfg_clr_gpio_14 |    |    |    | tdsel_cfg_clr_gpio_13 |    |    |    | tdsel_cfg_clr_gpio_12 |    |    |    | tdsel_cfg_clr_gpio_11 |    |    |    |
| <b>Type</b>  | WO                    |    |    |    |
| <b>Reset</b> | 0                     | 0  | 0  | 0  | 0                     | 0  | 0  | 0  | 0                     | 0  | 0  | 0  | 0                     | 0  | 0  | 0  |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b>           | <b>Description</b>                          |
|---------------|-----------------|-----------------------|---------------------------------------------|
| 27:24         |                 | tdsel_cfg_clr_gpio_17 | <b>PAD_GPIO_17</b><br>0: Keep; 1: Clear bit |
| 23:20         |                 | tdsel_cfg_clr_gpio_16 | <b>PAD_GPIO_16</b><br>0: Keep; 1: Clear bit |
| 19:16         |                 | tdsel_cfg_clr_gpio_15 | <b>PAD_GPIO_15</b><br>0: Keep; 1: Clear bit |
| 15:12         |                 | tdsel_cfg_clr_gpio_14 | <b>PAD_GPIO_14</b><br>0: Keep; 1: Clear bit |
| 11:8          |                 | tdsel_cfg_clr_gpio_13 | <b>PAD_GPIO_13</b><br>0: Keep; 1: Clear bit |
| 7:4           |                 | tdsel_cfg_clr_gpio_12 | <b>PAD_GPIO_12</b><br>0: Keep; 1: Clear bit |
| 3:0           |                 | tdsel_cfg_clr_gpio_11 | <b>PAD_GPIO_11</b><br>0: Keep; 1: Clear bit |

## 22. Clock Configuration

The clock configuration including the clock frequency settings and measuring methods are described.

The clock settings to be configured:

- Slow BUS clock and related peripheral clock
- Cortex-M4 MCU and fast BUS clock and related peripheral clock
- Serial Flash Controller (SFC)
- MSDC (SDIOMST)
- SPI Master (SPIMST)
- Clock frequency measuring methods

### 22.1. Clock configuration programming guide

The clock settings are configured by control registers (CRs) that control clock dividers and multiplexers (MUXs). This section describes how to switch clock source or frequency for system and peripheral devices and clock turn on/off methods. The clock source architecture is shown in Figure 22.1-1. The clock multiplexers of each clock are listed in Table 22.1-1.

General clock switch sequence is:

- 1) Turn on the PLL divider
- 2) Select the clock frequency
- 3) Ensure successful clock frequency switch
- 4) Trigger clock change bit
- 5) Poll clock change status

Note, that before switching clock frequencies, wait for the enabled clock to stabilize. Also, follow the minimum VCORE voltage limitation, or there will be timing violation issues. Clocks derived from BBPLL1 cannot be used when [RF\\_WBAC0\[16\]](#) is 0 (BBPLL1 is 832MHz).



Figure 22.1-1. Clock source architecture

Table 22.1-1. Clock switch

| Clock name   | MUX select register<br>(active when CHG=1) | SEL | MUX select option | Clock frequency (MHz) |
|--------------|--------------------------------------------|-----|-------------------|-----------------------|
| HF_FSYS_CK   | CKSYS_CLK_CFG_0__F_CLK_SYS_SEL             | 0   | xo_ck             | 26/20                 |
|              |                                            | 1   | BBPLL2_D5         | 192                   |
|              |                                            | 2   | BBPLL2_D5_D2      | 96                    |
|              |                                            | 3   | BBPLL1_D7         | 148.5714286           |
| HF_FSFC_CK   | CKSYS_CLK_CFG_0__F_CLK_SFC_SEL             | 0   | xo_ck             | 26/20                 |
|              |                                            | 1   | BBPLL2_D3_D4      | 80                    |
|              |                                            | 2   | BBPLL2_D15        | 64                    |
|              |                                            | 3   | BBPLL1_D7_D2      | 74.28571429           |
| F_FSPIMST_CK | CKSYS_CLK_CFG_0__F_CLK_SPIMST_SEL          | 0   | xo_ck             | 26/20                 |
|              |                                            | 1   | BBPLL2_D5_D4      | 48                    |
|              |                                            | 2   | BBPLL2_D5_D2      | 96                    |
| F_FSDIMST_CK | CKSYS_CLK_CFG_1__F_CLK_SDIMST_SEL          | 0   | xo_ck             | 26/20                 |
|              |                                            | 1   | BBPLL2_D5_D8      | 24                    |

| Clock name | MUX select register<br>(active when CHG=1) | SEL | MUX select<br>option | Clock<br>frequency<br>(MHz) |
|------------|--------------------------------------------|-----|----------------------|-----------------------------|
|            |                                            | 2   | BBPLL2_D5_D4         | 48                          |

Note 1: The MUX select register naming (CKSYS\_CLK\_CFG\_0\_F\_CLK\_SYS\_SEL) is in two parts - register address name (CKSYS\_CLK\_CFG\_0) and register bit name (F\_CLK\_SYS\_SEL).

Note 2: BBPLL2\_D5\_D2 means BBPLL2 (960MHz) is divided by 5 and then divided by 2 (equal to divide by 10)

### 22.1.1. Clock configuration for slow bus clock peripherals

Several slow bus clock peripherals (SEJ, AUXADC, eFUSE and more) share the same bus clock (FXO). The clock output of these peripherals is gated by clock gating cells. To turn on these clocks, the related power down (PDN) bit must be set. XO\_PDN\_SETDO is used to turn off the clock, while XO\_PDN\_CLRDO is used to turn on the clock. XO\_PDN\_COND0 is used to read configuration results (0: Clock is turned on; 1: Clock is gated off). Relationships between XO\_PDN\_COND0 bit numbers and different configure register names are shown in Table 22.1-2.

**Table 22.1-2. Relationship between XO\_PDN\_COND0 bit number and configuration register**

| Crystal oscillator power down conditions<br>XO_PDN_COND0[bit number] | Configuration register |
|----------------------------------------------------------------------|------------------------|
| XO_PDN_COND0[18]                                                     | RG_SW_EFUSE(CG)        |
| XO_PDN_COND0[17]                                                     | RG_SW_GPTIMER(CG)      |
| XO_PDN_COND0[16]                                                     | RG_SW_SPM(CG)          |
| XO_PDN_COND0[9]                                                      | RG_SW_PWM5(CG)         |
| XO_PDN_COND0[8]                                                      | RG_SW_PWM4(CG)         |
| XO_PDN_COND0[7]                                                      | RG_SW_PWM3(CG)         |
| XO_PDN_COND0[6]                                                      | RG_SW_PWM2(CG)         |
| XO_PDN_COND0[5]                                                      | RG_SW_PWM1(CG)         |
| XO_PDN_COND0[4]                                                      | RG_SW_PWM0(CG)         |
| XO_PDN_COND0[3]                                                      | RG_SW_SEJ(CG)          |

An example to turn on the clock source of PWM0:

- Write: XO\_PDN\_CLRDO = 0x10
- Read XO\_PDN\_COND0 = 0xFFFF

An example to turn off the clock source of PWM0:

- Write: XO\_PDN\_SETDO = 0x10
- Read XO\_PDN\_COND0 = 0x0000

### 22.1.2. Clock configuration for Cortex-M4 MCU and fast bus clock peripherals

The system clock (HF\_FSYS\_CK) supports F\_FXO\_CK clock (26MHz or 20MHz), 96MHz and maximum 192MHz (divided from PLL). The clock multiplexer switch method of HF\_FSYS\_CK is in Table 22.1-3.

An example of switching HF\_FSYS\_CK to 96MHz:

**Table 22.1-3. Clock multiplexer switch method of HF\_FSYS\_CK**

| Action  | Parameter                                | Value |
|---------|------------------------------------------|-------|
| Write   | CKSYS_CLK_DIV_1__F_CLK_PLL2_D5_EN        | 0 x 1 |
| Write   | CKSYS_CLK_DIV_2__F_CLK_PLL2_DIV_EN       | 0 x 1 |
| Write   | CKSYS_CLK_CFG_0__F_CLK_SYS_SEL           | 0 x 2 |
| Write   | CKSYS_CLK_FORCE_ON_0__F_CLK_SYS_FORCE_ON | 0 x 1 |
| Write   | CKSYS_CLK_UPDATE_0__F_CHG_SYS            | 0 x 1 |
| Polling | CKSYS_CLK_UPDATE_0__F_CHG_SYS            | 0 x 1 |
| Polling | CKSYS_CLK_UPDATE_STATUS_0__F_CHG_SYS_OK  | 0 x 1 |
| Write   | CKSYS_CLK_FORCE_ON_0__F_CLK_SYS_FORCE_ON | 0 x 0 |

EMI/SFC AHB BUS (FBUS) clocks are derived from HF\_FSYS\_CK clock and are half of Cortex-M4 MCU clock frequency. The bus clock is gated or slowed down (>1MHz), if there is no transaction. Clocks of several peripherals (I2C from 0 to 3, Crypto Engine, DMA and more) are the same as fast bus (FBUS). The clock output of these peripherals is gated by clock gating cells. To turn on these clocks, the related power down (PDN) bit must be set. PDN\_SET0 is used to turn off the clock, while PDN\_CLR0 is used to turn on the clock. PDN\_COND0 is used to read configuration results (0: Clock is turned on; 1: Clock is gated off). Relationships between PDN\_COND0 bit numbers and different configure register names are shown in Table 22.1-4.

**Table 22.1-4. Relationship between PDN\_COND0 bit number and configuration register**

| Power down conditions<br>PDN_COND0[bit number] | Configuration register | Power down<br>conditions<br>PDN_COND0[bit<br>number] | Configuration register |
|------------------------------------------------|------------------------|------------------------------------------------------|------------------------|
| PDN_COND0[22]                                  | RG_SW_SDIOSLV(CG)      | PDN_COND0[10]                                        | RG_SW_UART2(CG)        |
| PDN_COND0[21]                                  | RG_SW_CRYPTO(CG)       | PDN_COND0[9]                                         | RG_SW_UART1(CG)        |
| PDN_COND0[20]                                  | RG_SW_UART0(CG)        | PDN_COND0[8]                                         | RG_SW_SDIMST(CG)       |
| PDN_COND0[19]                                  | RG_SW_XTALCTL(CG)      | PDN_COND0[6]                                         | RG_SW_SPIMST(CG)       |
| PDN_COND0[18]                                  | RG_SW_TRNG(CG)         | PDN_COND0[5]                                         | RG_SW_SPISLV(CG)       |
| PDN_COND0[17]                                  | RG_SFC_SW(CG)          | PDN_COND0[3]                                         | RG_SW_SDIMST_BUS(CG)   |
| PDN_COND0[16]                                  | RG_SW_CM_SYSROM(CG)    | PDN_COND0[2]                                         | RG_SW_CONN_XO(CG)      |
| PDN_COND0[13]                                  | RG_SW_I2C1(CG)         | PDN_COND0[0]                                         | RG_SW_DMA(CG)          |
| PDN_COND0[12]                                  | RG_SW_I2C0(CG)         |                                                      |                        |

An example to turn on the clock of I2C0:

- Write: PDN\_CLR0 = 0x1000
- Read PDN\_COND0 = 0x2FFF

An example to turn off the clock of I2C0:

- Write: PDN\_SETDO = 0x1000
- Read PDN\_CONDO = 0x3FFF

### 22.1.3. Serial flash controller (SFC) clock setting

The serial flash controller clock (HF\_FSFC\_CK) supports F\_FXO\_CK clock (26MHz or 20MHz) and 80MHz (divided from PLL). The clock multiplexer switch method of HF\_FSFC\_CK is shown in Table 22.1-5.

An example to switch HF\_FSFC\_CK to 80MHz:

**Table 22.1-5. Clock multiplexer switch method of HF\_FSFC\_CK**

| Action  | Parameter                                | Value |
|---------|------------------------------------------|-------|
| Write   | CKSYS_CLK_DIV_1__F_CLK_PLL2_D3_EN        | 0 x 1 |
| Write   | CKSYS_CLK_DIV_2__F_CLK_PLL2_DIV_EN       | 0 x 1 |
| Write   | CKSYS_CLK_CFG_0__F_CLK_SFC_SEL           | 0 x 1 |
| Write   | CKSYS_CLK_FORCE_ON_0__F_CLK_SFC_FORCE_ON | 0 x 1 |
| Write   | CKSYS_CLK_UPDATE_0__F_CHG_SFC            | 0 x 1 |
| Polling | CKSYS_CLK_UPDATE_0__F_CHG_SFC            | 0 x 1 |
| Polling | CKSYS_CLK_UPDATE_STATUS_0__F_CHG_SFC_OK  | 0 x 1 |
| Write   | CKSYS_CLK_FORCE_ON_0__F_CLK_SFC_FORCE_ON | 0 x 0 |

To turn off the SFC when not in use, set PDN\_SETDO to 0x20000.

### 22.1.4. MSDC (SDIOMST) clock setting

The MSDC clock (F\_FSDIOMST\_CK) supports F\_FXO\_CK clock (26MHz or 20MHz), 24MHz and maximum 48MHz (divided from PLL). The clock multiplexer switch method of F\_FSDIOMST\_CK is shown in Table 22.1-6.

An example to switch F\_FSDIOMST\_CK to 48MHz:

**Table 22.1-6. Clock multiplexer switch method of F\_FSDIOMST\_CK**

| Action  | Parameter                                    | Value |
|---------|----------------------------------------------|-------|
| Write   | CKSYS_CLK_DIV_1__F_CLK_PLL2_D5_EN            | 0 x 1 |
| Write   | CKSYS_CLK_DIV_2__F_CLK_PLL2_DIV_EN           | 0 x 1 |
| Write   | CKSYS_CLK_CFG_0__F_CLK_SDIOMST_SEL           | 0 x 2 |
| Write   | CKSYS_CLK_FORCE_ON_1__F_CLK_SDIOMST_FORCE_ON | 0 x 1 |
| Write   | CKSYS_CLK_UPDATE_1__F_CHG_SDIOMST            | 0 x 1 |
| Polling | CKSYS_CLK_UPDATE_1__F_CHG_SDIOMST            | 0 x 1 |
| Polling | CKSYS_CLK_UPDATE_STATUS_1__F_CHG_SDIOMST_OK  | 0 x 1 |
| Write   | CKSYS_CLK_FORCE_ON_1__F_CLK_SDIOMST_FORCE_ON | 0 x 0 |

To turn off the SDIOMST clock when not in use, set PDN\_SETDO to 0x100.

### 22.1.5. SPI Master (SPIMST) clock setting

The SPI master clock is half of F\_FSPIMST\_CK. F\_FSPIMST\_CK supports F\_FXO\_CK clock (26MHz or 20MHz), 48MHz and maximum 96MHz (divided from PLL). The clock multiplexer switch method of F\_FSPIMST\_CK is shown in Table 22.1-7.

An example to switch F\_FSPIMST\_CK to 96MHz:

**Table 22.1-7. Clock multiplexer switch method of F\_FSDIOMST\_CK**

| Action  | Parameter                                   | Value |
|---------|---------------------------------------------|-------|
| Write   | CKSYS_CLK_DIV_1__F_CLK_PLL2_D5_EN           | 0 x 1 |
| Write   | CKSYS_CLK_DIV_2__F_CLK_PLL2_DIV_EN          | 0 x 1 |
| Write   | CKSYS_CLK_CFG_0__F_CLK_SPIMST_SEL           | 0 x 2 |
| Write   | CKSYS_CLK_FORCE_ON_1__F_CLK_SPIMST_FORCE_ON | 0 x 1 |
| Write   | CKSYS_CLK_UPDATE_1__F_CHG_SPIMST            | 0 x 1 |
| Polling | CKSYS_CLK_UPDATE_1__F_CHG_SPIMST            | 0 x 1 |
| Polling | CKSYS_CLK_UPDATE_STATUS_1__F_CHG_SPIMST_OK  | 0 x 1 |
| Write   | CKSYS_CLK_FORCE_ON_1__F_CLK_SPIMST_FORCE_ON | 0 x 0 |

To turn off the SPIMST clock when not in use, first set PDN\_SETD0 to 0x8, then set PDN\_SETD0 to 0x40.

### 22.1.6. Measuring the clock frequency

There is a circuit to measure the output frequency of clock switch. The general sequence is:

- 1) Set the DUT clock (FQMTR\_CK), as shown in Table 22.1-8.
- 2) Reset the frequency meter.
- 3) Set the fixed clock cycle numbers by FQMTR\_WINSET, fixed clock default is F\_FXO\_CK
- 4) Enable the frequency meter.
- 5) Wait for the measurement to complete.
- 6) Estimate the FQMTR\_CK frequency (a decimal number) according the formula :

$$FQMTR_{CK} = \frac{FQMTR\_DATA[23:0]}{FQMTR\_WINSET + 1} \times FIXED\_CK$$

**Table 22.1-8. Clock multiplexer switch method of F\_FSDIOMST\_CK**

| CKSYS_TST_SEL_1 setting of DUT clock (FQMTR_CK) | Clock name    |
|-------------------------------------------------|---------------|
| 0x11                                            | HF_FSFC_CK    |
| 0x13                                            | HF_FSYS_CK    |
| 0x14                                            | F_FSPIMST_CK  |
| 0x15                                            | F_FSDIOMST_CK |

An example to measure whether HF\_FSYS\_CK is 96MHz is shown in Table 22.1-9:

Table 22.1-9. Clock multiplexer switch method of F\_FSDIOMST\_CK

| Action | Parameter            | Value  |
|--------|----------------------|--------|
| Write  | CKSYS_TST_SEL_1      | 0x13   |
| Write  | PLL_ABIST_FQMTR_CON0 | 0x4000 |
| Write  | PLL_ABIST_FQMTR_CON0 | 0xFFFF |
| Write  | PLL_ABIST_FQMTR_CON0 | 0xFFFF |

Wait for 5μs, then set PLL\_ABIST\_FQMTR\_CON1[15] to 0x0 in polling.

If XO is at 20MHz, read: PLL\_ABIST\_FQMTR\_DATA[23:0] = 0x4CCC.

$$FQMTR_{CK} = \frac{19660}{4095 + 1} \times 20\text{MHz} = 96\text{MHz}$$

## 22.2. Register mapping

### 22.2.1. bbpll\_ctrl register map

Module name: bbpll\_ctrl Base address: (+A2040000h)

| Address  | Name                     | Width | Register Functionality                        |
|----------|--------------------------|-------|-----------------------------------------------|
| A2040200 | <u>BBPLL REF CLK SEL</u> | 32    | <b>PLL Reference Clock Selection Register</b> |
| A2040300 | <u>RF_WBAC0</u>          | 32    | <b>RF PLL Related Control Register 0</b>      |
| A2040304 | <u>RF_WBAC1</u>          | 32    | <b>RF PLL Related Control Register 1</b>      |
| A2040308 | <u>RF_WBAC2</u>          | 32    | <b>RF PLL Related Control Register 2</b>      |
| A204030C | <u>RF_WBAC3</u>          | 32    | <b>RF PLL Related Control Register 3</b>      |
| A2040310 | <u>RF_WBAC4</u>          | 32    | <b>RF PLL Related Control Register 4</b>      |
| A2040314 | <u>RF_WBAC5</u>          | 32    | <b>RF PLL Related Control Register 5</b>      |
| A204031C | <u>RF_WBAC7</u>          | 32    | <b>RF PLL Control Stable Time 0</b>           |
| A2040320 | <u>RF_WBAC8</u>          | 32    | <b>RF PLL Control Stable Time 1</b>           |
| A2040324 | <u>RF_WBAC9</u>          | 32    | <b>RF PLL Control Stable Time 2</b>           |
| A2040328 | <u>RF_WBAC10</u>         | 32    | <b>RF PLL Control Stable Time 3</b>           |
| A204032C | <u>RF_WBAC11</u>         | 32    | <b>RF PLL Control Stable Time4</b>            |
| A2040330 | <u>RF_WBAC12</u>         | 32    | <b>RF PLL Control Stable Time 5</b>           |
| A2040334 | <u>RF_WBAC13</u>         | 32    | <b>RF PLL Control Stable Time 6</b>           |
| A2040338 | <u>RF_WBAC14</u>         | 32    | <b>RF PLL Control Stable Time 7</b>           |
| A204033C | <u>RF_WBAC15</u>         | 32    | <b>RF PLL Control Stable Time8</b>            |
| A2040340 | <u>RF_WBAC16</u>         | 32    | <b>RF PLL Control Stable Time 9</b>           |
| A2040344 | <u>RF_WBAC17</u>         | 32    | <b>RF PLL Manual Control Register 17</b>      |
| A2040348 | <u>RF_WBAC18</u>         | 32    | <b>RF PLL Manual Control Register 18</b>      |
| A204034C | <u>RF_WBAC19</u>         | 32    | <b>RF PLL Manual Control Register 19</b>      |
| A2040350 | <u>RF_WBAC20</u>         | 32    | <b>RF PLL Manual Control Register 20</b>      |
| A2040354 | <u>RF_WBAC21</u>         | 32    | <b>RF PLL Manual Control Register 21</b>      |
| A2040358 | <u>RF_WBAC22</u>         | 32    | <b>RF PLL Manual Control Register 22</b>      |
| A204035C | <u>RF_WBAC23</u>         | 32    | <b>RF PLL Manual Control Register 23</b>      |
| A2040360 | <u>RF_WBAC24</u>         | 32    | <b>RF PLL Manual Control Register 24</b>      |

| Address  | Name                  | Width | Register Functionality                      |
|----------|-----------------------|-------|---------------------------------------------|
| A2040364 | <u>RF WBAC25</u>      | 32    | <b>RF PLL Manual Control Register 25</b>    |
| A2040368 | <u>RF WBAC26</u>      | 32    | <b>RF PLL Manual Control Register 26</b>    |
| A2040370 | <u>RF WBAC27</u>      | 32    | <b>RF PLL Manual Control Register 27</b>    |
| A2040374 | <u>RF WBAC28</u>      | 32    | <b>RF PLL Manual Control Register 28</b>    |
| A2040384 | <u>RO RF WBAC1</u>    | 32    | <b>RF PLL Register 1 Status</b>             |
| A2040388 | <u>RO RF WBAC2</u>    | 32    | <b>RF PLL Register 2 Status</b>             |
| A204038C | <u>RO RF WBAC3</u>    | 32    | <b>RF PLL Control Stable Time 0 Status</b>  |
| A2040390 | <u>RO RF WBAC4</u>    | 32    | <b>RF PLL Control Stable Time 1 Status</b>  |
| A2040394 | <u>RO RF WBAC5</u>    | 32    | <b>RF PLL Control Stable Time 2 Status</b>  |
| A2040398 | <u>RO RF WBAC6</u>    | 32    | <b>RF PLL Control Stable Time 3 Status</b>  |
| A204039C | <u>RO RF WBAC7</u>    | 32    | <b>RF PLL Control Stable Time 4 Status</b>  |
| A20403A0 | <u>RO RF WBAC8</u>    | 32    | <b>RF PLL Control Stable Time 5 Status</b>  |
| A2040400 | <u>BBPLL DBG PROB</u> | 32    | <b>RF PLL Debug Probe</b>                   |
| A2040410 | <u>BBPLL RDY</u>      | 32    | <b>RF PLL Ready Status</b>                  |
| A2040700 | <u>PLLTD CONo</u>     | 32    | <b>RF PLL Time Delay Control Register 0</b> |

A2040200 BBPLL\_REF\_CL PLL reference clock selection register 00000001  
K SEL

| <b>Bit(s)</b> | <b>Mnemonic</b>             | <b>Name</b>                 | <b>Description</b>               |
|---------------|-----------------------------|-----------------------------|----------------------------------|
| 0             | <b>rg_bbpll_ref_clk_sel</b> | <b>RG_BBPLL_REF_CLK_SEL</b> | 1'b0: for PAD<br>1'b1: from XTAL |

A2040300 RF WBACo RF WBAC RG o 00010000

| <b>Bit(s)</b> | <b>Mnemonic</b>                      | <b>Name</b> | <b>Description</b>  |
|---------------|--------------------------------------|-------------|---------------------|
| 31:0          | <b>WBTAC_CM4_PLLCR_WBTAC_CM4_PLL</b> |             | [26] <b>CR_MODE</b> |

[25] CR\_SPM\_TURN\_ON\_BBPLL1\_EN  
[24] CR\_SPM\_TURN\_ON\_BBPLL2\_EN  
[16] BBPLL1\_FREQ\_SEL  
o: 832MHz  
1: 1040MHz  
[5] CR\_AFELDO\_FOLLOW\_TRXLDO  
[4] CR\_AFETRXLDO\_FOLLOW\_LDO  
[1] CR\_CONN\_TURN\_ON\_BBPLL1\_EN  
[0] CR\_CONN\_TURN\_ON\_BBPLL2\_EN

A2040304 RF WBAC1 RF WBAC RG 1 054B2840

| Bit          | 31                           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  | <b>RG_WF_BBPLL_01[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                            | 0  | 0  | 0  | 0  | 1  | 0  | 1  | 0  | 1  | 0  | 0  | 1  | 0  | 1  | 1  |
| <b>Bit</b>   | 15                           | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | <b>RG_WF_BBPLL_01[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                            | 0  | 1  | 0  | 1  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Mnemonic                               | Name                 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------|----------------------------------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | <b>RG_WF_BBPLLCR_RG_WF_BBPLL_01_01</b> | Wi-Fi PLL registers. | Actual RG_WF_BBPLL_01 = WBTAC_BBPLL_SW ?<br>RG_WF_BBPLL_01[31:0] :<br>case(BBPLL1_FREQ_SEL, xtal_freq)<br>5'b01000: BBPLL1=832 MHz, XTAL=52<br>MHz ,32'h45962040<br>5'bo0100: BBPLL1=832 MHz, XTAL=40<br>MHz ,32'h01234567<br>5'bo0010: BBPLL1=832 MHz, XTAL=26<br>MHz ,32'h45962040<br>5'bo0001: BBPLL1=832 MHz, XTAL=20<br>MHz ,32'h01234567<br>5'b11000: BBPLL1=1040 MHz, XTAL=52<br>MHz ,32'h454B2840<br>5'b10100: BBPLL1=1040 MHz, XTAL=40<br>MHz ,32'h454B3440<br>5'b10010: BBPLL1=1040 MHz, XTAL=26<br>MHz ,32'h054B2840<br>5'b10001: BBPLL1=1040 MHz, XTAL=20<br>MHz ,32'h054B3440<br>default : 32'h054B2840<br>endcase |

A2040308 RF WBAC2 RF WBAC RG 2 05691840

| Bit          | 31                           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  | <b>RG_WF_BBPLL_02[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                            | 0  | 0  | 0  | 0  | 1  | 0  | 1  | 0  | 1  | 1  | 0  | 1  | 0  | 0  | 1  |
| <b>Bit</b>   | 15                           | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | <b>RG_WF_BBPLL_02[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                            | 0  | 0  | 1  | 1  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Mnemonic                            | Name                               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------|-------------------------------------|------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | <b>RG_WF_BBPLLCR_RG_WF_BBPLL_02</b> | Wi-Fi PLL registers.<br><b>_o2</b> | Actual RG_WF_BBPLL_02 = WBTAC_BBPLL_SW ?<br>RG_WF_BBPLL_02[31:0] :<br>case(BBPLL1_FREQ_SEL, xtal_freq)<br>5'b01000: BBPLL1=832 MHz, XTAL=52<br>MHz ,32'h05691E40<br>5'b00100: BBPLL1=832 MHz, XTAL=40<br>MHz ,32'h45693040<br>5'b00010: BBPLL1=832 MHz, XTAL=26<br>MHz ,32'h05691E40<br>5'b00001: BBPLL1=832 MHz, XTAL=20<br>MHz ,32'h05693040<br>5'b11000: BBPLL1=1040 MHz, XTAL=52<br>MHz ,32'h05691840<br>5'b10100: BBPLL1=1040 MHz, XTAL=40<br>MHz ,32'h45693040<br>5'b10010: BBPLL1=1040 MHz, XTAL=26<br>MHz ,32'h05691840<br>5'b10001: BBPLL1=1040 MHz, XTAL=20<br>MHz ,32'h05693040<br>default : 32'h05691840<br>endcase |

| A204030C RF WBAC3 RF WBAC RG 3 |                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 000000FA |  |
|--------------------------------|------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|--|
| <b>Bit</b>                     | 31                           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16       |  |
| <b>Name</b>                    | <b>RG_WF_BBPLL_03[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |  |
| <b>Type</b>                    | RW                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |  |
| <b>Reset</b>                   | 0                            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0        |  |
| <b>Bit</b>                     | 15                           | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0        |  |
| <b>Name</b>                    | <b>RG_WF_BBPLL_03[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |  |
| <b>Type</b>                    | RW                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |  |
| <b>Reset</b>                   | 0                            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | 1  | 0  | 1  | 0        |  |

| Bit(s) | Mnemonic                        | Name                      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------|---------------------------------|---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | RG_WF_BBPLL_O CR_RG_WF_BBPLL_03 | Wi-Fi PLL registers.<br>3 | Actual RG_WF_BBPLL_03= WBTAC_BBPLL_SW ?<br>RG_WF_BBPLL_03[31:0] :<br>case(BBPLL1_FREQ_SEL, xtal_freq)<br>5'b01000: BBPLL1=832 MHz, XTAL=52<br>MHz ,32'h000000FA<br>5'b00100: BBPLL1=832 MHz, XTAL=40<br>MHz ,32'hC00001FA<br>5'b00010: BBPLL1=832 MHz, XTAL=26<br>MHz ,32'h000000FA<br>5'b00001: BBPLL1=832 MHz, XTAL=20<br>MHz ,32'hC00001FA<br>5'b11000: BBPLL1=1040 MHz, XTAL=52<br>MHz ,32'h000000FA<br>5'b10100: BBPLL1=1040 MHz, XTAL=40<br>MHz ,32'hC00001FA<br>5'b10010: BBPLL1=1040 MHz, XTAL=26<br>MHz ,32'h000000FA<br>5'b10001: BBPLL1=1040 MHz, XTAL=20 |

MHz ,32'hC00001FA  
default : 32'h000000FA  
endcase

A2040310 RF\_WBAC4 RF WBAC RG 4 00000000

| Bit   | 31                    | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|-----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | RG_WF_BBPLL_04[31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                     | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15                    | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | RG_WF_BBPLL_04[15:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                     | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Mnemonic                        | Name              | Description                                                              |
|--------|---------------------------------|-------------------|--------------------------------------------------------------------------|
| 31:0   | RG_WF_BBPLL_0 CR_RG_WF_BBPLL_04 | CR_RG_WF_BBPLL_04 | Wi-Fi PLL registers.                                                     |
| 4      |                                 |                   | Actual RG_WF_BBPLL_04 = WBTAC_BBPLL_SW ?<br>RG_WF_BBPLL_04[31:0] : 32'ho |

A2040314 RF\_WBAC5 RF WBAC RG 5 00000000

| Bit   | 31                    | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|-----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | RG_WF_BBPLL_05[31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                     | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15                    | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | RG_WF_BBPLL_05[15:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                     | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Mnemonic                     | Name              | Description                                                              |
|--------|------------------------------|-------------------|--------------------------------------------------------------------------|
| 31:0   | RG_WF_BBPL CR_RG_WF_BBPLL_05 | CR_RG_WF_BBPLL_05 | Wi-Fi PLL registers.                                                     |
| L_05   |                              |                   | Actual RG_WF_BBPLL_05 = WBTAC_BBPLL_SW ?<br>RG_WF_BBPLL_05[31:0] : 32'ho |

A204031C RF\_WBAC7 RF WBAC STABLE TIME 0 01040186

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 0  |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 0  | 0  | 0  | 0  | 1  | 1  | 0  | 0  |

| Bit(s) | Mnemonic                            | Name                                       | Description                                                       |
|--------|-------------------------------------|--------------------------------------------|-------------------------------------------------------------------|
| 29:16  | WBTAC_LSFLDO_STCR_WBTAC_LSFLDO_STAB | WBTAC_LSFLDO_STABLE_TIME[13:0] = ABLE_TIME | Actual WBTAC_LSFLDO_STABLE_TIME[13:0] = ABLE_TIME                 |
|        | LE_TIME                             |                                            | WBTAC_LSFLDO_STABLE_TIME_SW ?<br>WBTAC_LSFLDO_STABLE_TIME[13:0] : |

---

|      |                                                                            |                                                                                                                                                                                                                           |
|------|----------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                                                                            | case(f_fxo_is_26m)<br>1'b1: f_fxo_ck=26 MHz ,14'd260<br>1'bo: f_fxo_ck=20 MHz ,14'd200<br>endcase                                                                                                                         |
| 13:0 | WBTAC_RFDIG_VC CR_WBTAC_RFDIG_VCORE Actual<br>ORE_STABLE_TIME _STABLE_TIME | WBTAC_RFDIG_VCORE_STABLE_TIME[13:0] =<br>WBTAC_RFDIG_VCORE_STABLE_TIME_SW ?<br>WBTAC_RFDIG_VCORE_STABLE_TIME[13:0] :<br>case(f_fxo_is_26m)<br>1'b1: f_fxo_ck=26 MHz ,14'd416<br>1'bo: f_fxo_ck=20 MHz ,14'd320<br>endcase |

---

| A2040320 RF WBAC8 RF WBAC STABLE TIME 1 |                                         |    |    |    |    |    |    |    |    |    |    |    |    |    | 016C01BA |    |
|-----------------------------------------|-----------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|----|
| Bit                                     | 31                                      | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17       | 16 |
| Name                                    | <b>WBTAC_RFDIG_LSFLDO_STABLE_TIME</b>   |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |
| Type                                    | RW                                      |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |
| Reset                                   | 0                                       | 0  | 0  | 0  | 0  | 1  | 0  | 1  | 1  | 0  | 1  | 1  | 0  | 1  | 0        | 0  |
| Bit                                     | 15                                      | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1        | 0  |
| Name                                    | <b>WBTAC_LSFLDO_OUT_SEL_STABLE_TIME</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |
| Type                                    | RW                                      |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |
| Reset                                   | 0                                       | 0  | 0  | 0  | 0  | 1  | 1  | 0  | 1  | 1  | 1  | 0  | 1  | 0  | 0        | 0  |

---

| Bit(s) | Mnemonic                                                                            | Name                                                                                                                                                                                                                               | Description |
|--------|-------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 29:16  | WBTAC_RFDIG_L CR_WBTAC_RFDIG_LSF Actual<br>SFLDO_STABLE_ LDO_STABLE_TIME<br>TIME    | WBTAC_RFDIG_LSFLDO_STABLE_TIME[13:0] =<br>WBTAC_RFDIG_LSFLDO_STABLE_TIME_SW ?<br>WBTAC_RFDIG_LSFLDO_STABLE_TIME[13:0] :<br>case(f_fxo_is_26m)<br>1'b1: f_fxo_ck=26 MHz ,14'd312<br>1'bo: f_fxo_ck=20 MHz ,14'd240<br>endcase       |             |
| 13:0   | WBTAC_LSFLDO_CR_WBTAC_LSFLDO_O Actual<br>OUT_SEL_STABL UT_SEL_STABLE_TIME<br>E_TIME | WBTAC_LSFLDO_OUT_SEL_STABLE_TIME[13:0] =<br>WBTAC_LSFLDO_OUT_SEL_STABLE_TIME_SW ?<br>WBTAC_LSFLDO_OUT_SEL_STABLE_TIME[13:0] :<br>case(f_fxo_is_26m)<br>1'b1: f_fxo_ck=26 MHz ,14'd468<br>1'bo: f_fxo_ck=20 MHz ,14'd360<br>endcase |             |

---

| A2040324 RF WBAC9 RF WBAC STABLE TIME 2 |                                 |    |    |    |    |    |    |    |    |    |    |    |    |    | 01EE03F6 |    |
|-----------------------------------------|---------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----------|----|
| Bit                                     | 31                              | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17       | 16 |
| Name                                    | <b>WBTAC_LDO_STABLE_TIME</b>    |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |
| Type                                    | RW                              |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |
| Reset                                   | 0                               | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | 1  | 0  | 1  | 1  | 1  | 0        | 0  |
| Bit                                     | 15                              | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1        | 0  |
| Name                                    | <b>WBTAC_BBPLL1_STABLE_TIME</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |
| Type                                    | RW                              |    |    |    |    |    |    |    |    |    |    |    |    |    |          |    |
| Reset                                   | 0                               | 0  | 0  | 0  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 0  | 1  | 1  | 0        | 0  |

| <b>Bit(s)</b> | <b>Mnemonic</b>           | <b>Name</b>                  | <b>Description</b>                                                                                                                                                                                                          |
|---------------|---------------------------|------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29:16         | WBTAC_LDO_STABLE_TIME     | CR_WBTAC_LDO_STABLE_TIME     | <b>Actual</b><br>WBTAC_LDO_STABLE_TIME[13:0] =<br>WBTAC_LDO_STABLE_TIME_SW ?<br>WBTAC_LDO_STABLE_TIME[13:0] :<br>case(f_fxo_is_26m)<br>1'b1: f_fxo_ck=26 MHz ,14'd494<br>1'bo: f_fxo_ck=20 MHz ,14'd380<br>endcase          |
| 13:0          | WBTAC_BBPLL1_STABL_E_TIME | CR_WBTAC_BBPLL1_STABL_E_TIME | <b>Actual</b><br>WBTAC_BBPLL1_STABLE_TIME[13:0] =<br>WBTAC_BBPLL1_STABLE_TIME_SW ?<br>WBTAC_BBPLL1_STABLE_TIME[13:0] :<br>case(f_fxo_is_26m)<br>1'b1: f_fxo_ck=26 MHz ,14'd520<br>1'bo: f_fxo_ck=20 MHz ,14'd400<br>endcase |

A2040328 RF WBAC10 RF WBAC STABLE TIME 3 090A090A

| <b>Bit(s)</b> | <b>Mnemonic</b>                    | <b>Name</b>                           | <b>Description</b>                                                                                                                                                                                                                       |
|---------------|------------------------------------|---------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29:16         | WBTAC_BBPLL2_STA<br>BLE_TIME       | CR_WBTAC_BBPLL2_ST<br>ABLE_TIME       | Actual<br>WBTAC_BBPLL2_STABLE_TIME[13:0] =<br>WBTAC_BBPLL2_STABLE_TIME_SW ?<br>WBTAC_BBPLL2_STABLE_TIME[13:0] :<br>case(f_fxo_is_26m)<br>1'b1: f_fxo_ck=26 MHz ,14'd1820<br>1'bo: f_fxo_ck=20 MHz ,14'd400<br>endcase                    |
| 13:0          | WBTAC_BBPLL1_CKD<br>IG_STABLE_TIME | CR_WBTAC_BBPLL1_CK<br>DIG_STABLE_TIME | Actual<br>WBTAC_BBPLL1_CKDIG_STABLE_TIME[13:0] =<br>WBTAC_BBPLL1_CKDIG_STABLE_TIME_SW ?<br>WBTAC_BBPLL1_CKDIG_STABLE_TIME[13:0] :<br>case(f_fxo_is_26m)<br>1'b1: f_fxo_ck=26 MHz ,14'd1820<br>1'bo: f_fxo_ck=20 MHz ,14'd1400<br>endcase |

A204032C RF WBAC11 RF WBAC STABLE TIME4 00340068

| Bit   | 15                                 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|------------------------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | <b>WBTAC_RFDIG_LSFLDO_OFF_TIME</b> |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | RW                                 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0 0 1 1 0 1 0 0 0                  |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |

| Bit(s) | Mnemonic                       | Name                              | Description                                                                                                                                                                                                     |
|--------|--------------------------------|-----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24:16  | WBTAC_RFDIG_VCORE<br>_OFF_TIME | CR_WBTAC_RFDIG_VCORE<br>_OFF_TIME | WBTAC_RFDIG_VCORE_OFF_TIME[8:0] =<br>WBTAC_RFDIG_VCORE_OFF_TIME_SW ?<br>WBTAC_RFDIG_VCORE_OFF_TIME[8:0] :<br>case(f_fxo_is_26m)<br>1'b1: f_fxo_ck=26 MHz ,9'd78<br>1'bo: f_fxo_ck=20 MHz ,9'd60<br>endcase      |
| 8:0    | WBTAC_RFDIG_LSFLD<br>_OFF_TIME | CR_WBTAC_RFDIG_LSFLD<br>_OFF_TIME | WBTAC_RFDIG_LSFLDO_OFF_TIME[8:0] =<br>WBTAC_RFDIG_LSFLDO_OFF_TIME_SW ?<br>WBTAC_RFDIG_LSFLDO_OFF_TIME[8:0] :<br>case(f_fxo_is_26m)<br>1'b1: f_fxo_ck=26 MHz ,9'd130<br>1'bo: f_fxo_ck=20 MHz ,9'd100<br>endcase |

| A2040330 RF_WBAC12 RF WBAC STABLE TIME 5 oF3C001A |                                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
|---------------------------------------------------|-----------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Bit                                               | 31                                      | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
| Name                                              | <b>WBTAC_BBPLL2_960M_CK_STABLE_TIME</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                                              | RW                                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset                                             | 0 0 1 1 1 1 0 0 1 1 1 1 0 0             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit                                               | 15                                      | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name                                              | <b>WBTAC_RDY_STABLE_TIME</b>            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type                                              | RW                                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset                                             | 0 0 0 0 0 0 1 1 0 1 0 1 0 1 0 0         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit(s) | Mnemonic                                           | Name   | Description                                                                                                                                                                                                                          |
|--------|----------------------------------------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29:16  | WBTAC_BBPLL2_9 CR_WBTAC_BBPLL2_960<br>TIME         | Actual | WBTAC_BBPLL2_960M_CK_STABLE_TIME[13:0] =<br>WBTAC_BBPLL2_960M_CK_STABLE_TIME_SW ?<br>WBTAC_BBPLL2_960M_CK_STABLE_TIME[13:0] :<br>case(f_fxo_is_26m)<br>1'b1: f_fxo_ck=26 MHz ,14'd1300<br>1'bo: f_fxo_ck=20 MHz ,14'd1000<br>endcase |
| 8:0    | WBTAC_RDY_STA CR_WBTAC_RDY_STAB<br>BLE_TIME E_TIME | Actual | WBTAC_RDY_STABLE_TIME[8:0] =<br>WBTAC_RDY_STABLE_TIME_SW ?<br>WBTAC_RDY_STABLE_TIME[8:0] :<br>case(f_fxo_is_26m)<br>1'b1: f_fxo_ck=26 MHz ,9'd26<br>1'bo: f_fxo_ck=20 MHz ,9'd20<br>endcase                                          |

A2040334 RF WBAC13 RF WBAC STABLE TIME 6 00000504

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24                      | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                       |   |
|-------|----|----|----|----|----|----|----|-------------------------|----|----|----|----|----|----|----|--------------------------|---|
| Name  |    |    |    |    |    |    |    |                         |    |    |    |    |    |    |    | WBTAC_LSFLDO_OUT_SEL_OFF |   |
| Type  |    |    |    |    |    |    |    |                         |    |    |    |    |    |    |    | RW                       |   |
| Reset |    |    |    |    |    |    |    |                         |    |    |    |    |    |    | 0  | 0                        | 0 |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8                       | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                        |   |
| Name  |    |    |    |    |    |    |    | WBTAC_LSFLDO_OUT_SEL_ON |    |    |    |    |    |    |    | WBTAC_PALDO_BACKOFF_TIME |   |
| Type  |    |    |    |    |    |    |    | RW                      |    |    |    |    |    |    |    | RW                       |   |
| Reset |    |    |    |    |    |    |    | 1                       | 0  | 1  |    |    |    |    | 1  | 0                        | 0 |

| Bit(s) | Mnemonic                                             | Name                              | Description |
|--------|------------------------------------------------------|-----------------------------------|-------------|
| 18:16  | WBTAC_LSFLDO_OUT_SEL_OFF CR_WBTAC_LSFLDO_OUT_SEL_OFF | LSFLDO turn on voltage selection  |             |
| 10:8   | WBTAC_LSFLDO_OUT_SEL_ON CR_WBTAC_LSFLDO_OUT_SEL_ON   | LSFLDO turn off voltage selection |             |
| 2:0    | WBTAC_PALDO_BACKOFF_TIME CR_WBTAC_PALDO_BACKOFF_TIME | Reserved                          |             |

A2040338 RF WBAC14 RF WBAC STABLE TIME 7 00000000

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24                                | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                                   |
|-------|----|----|----|----|----|----|----|-----------------------------------|----|----|----|----|----|----|----|--------------------------------------|
| Name  |    |    |    |    |    |    |    | WBTAC_LSFLD_O_ST_ABLE_TIM_E_SW    |    |    |    |    |    |    |    | WBTAC_RFDIG_LSFLD_O_ST_ABLE_TIM_E_SW |
| Type  |    |    |    |    |    |    |    | RW                                |    |    |    |    |    |    |    | RW                                   |
| Reset |    |    |    |    |    |    |    | 0                                 |    |    |    |    |    |    |    | 0                                    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8                                 | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                                    |
| Name  |    |    |    |    |    |    |    | WBTAC_BPLL1_CKDIG_STABLE_TIM_E_SW |    |    |    |    |    |    |    | WBTAC_BBPLL1_CKDIG_STABLE_TIM_E_SW   |
| Type  |    |    |    |    |    |    |    | RW                                |    |    |    |    |    |    |    | RW                                   |
| Reset |    |    |    |    |    |    |    | 0                                 |    |    |    |    |    |    |    | 0                                    |

| Bit(s) | Mnemonic                               | Name                                                       | Description                          |
|--------|----------------------------------------|------------------------------------------------------------|--------------------------------------|
| 24     | WBTAC_LSFLDO_ST CR_WBTAC_LSFLDO_STAB   | Manual mode switch for ABLE_TIME_SW LE_TIME_SW             | WBTAC_LSFLDO_STABLE_TIME[13:0]       |
| 16     | WBTAC_RFDIG_LSFLD CR_WBTAC_RFDIG_LSFLD | Manual mode switch for DO_STABLE_TIME_S O_STABLE_TIME_SW W | WBTAC_RFDIG_LSFLD_STABLE_TIME[13:0]  |
| 8      | WBTAC_BBPLL1_CKDCR_WBTAC_BBPLL1_CKDI   | Manual mode switch for IG_STABLE_TIME_S G_STABLE_TIME_SW W | WBTAC_BBPLL1_CKDIG_STABLE_TIME[13:0] |
| 0      | WBTAC_BBPLL1_STA CR_WBTAC_BBPLL1_STABL | Manual mode switch for                                     |                                      |

BLE\_TIME\_SW

E\_TIME\_SW

WBTAC\_BBPLL1\_STABLE\_TIME[13:0]

A204033C RF WBAC15 RF WBAC STABLE TIME8 00000000

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24                                                                  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                                                      |
|-------|----|----|----|----|----|----|----|---------------------------------------------------------------------|----|----|----|----|----|----|----|---------------------------------------------------------|
| Name  |    |    |    |    |    |    |    | WBT<br>AC_R<br>FDIG<br>_VCO<br>RE_S<br>TABL<br>E_TI<br>ME_S<br>W    |    |    |    |    |    |    |    | WBT<br>AC_L<br>DO_S<br>TABL<br>E_TI<br>ME_S<br>W        |
| Type  |    |    |    |    |    |    |    | RW                                                                  |    |    |    |    |    |    |    | RW                                                      |
| Reset |    |    |    |    |    |    |    | 0                                                                   |    |    |    |    |    |    |    | 0                                                       |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8                                                                   | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                                                       |
| Name  |    |    |    |    |    |    |    | WBT<br>AC_L<br>SFLD<br>O_OU<br>T_SE<br>L_ST<br>ABLE<br>_TIM<br>E_SW |    |    |    |    |    |    |    | WBT<br>AC_B<br>BPLL<br>2_ST<br>ABLE<br>_TIM<br>E_S<br>W |
| Type  |    |    |    |    |    |    |    | RW                                                                  |    |    |    |    |    |    |    | RW                                                      |
| Reset |    |    |    |    |    |    |    | 0                                                                   |    |    |    |    |    |    |    | 0                                                       |

| Bit(s) | Mnemonic                           | Name                                                                                                            | Description |
|--------|------------------------------------|-----------------------------------------------------------------------------------------------------------------|-------------|
| 24     | WBTAC_RFDIG_VCORECR_WBTAC_RFDIG_V  | Manual mode switch for<br>_STABLE_TIME_SW CORE_STABLE_TIME WBTAC_RFDIG_VCORE_STABLE_TIME[13:0]<br>_SW           |             |
| 16     | WBTAC_LDO_STABLE_CR_WBTAC_LDO_STA  | Manual mode switch for<br>TIME_SW BLE_TIME_SW WBTAC_LDO_STABLE_TIME[13:0]                                       |             |
| 8      | WBTAC_LSFLDO_OUT_CR_WBTAC_LSFLDO_  | Manual mode switch for<br>SEL_STABLE_TIME_S OUT_SEL_STABLE_TI WBTAC_LSFLDO_OUT_SEL_STABLE_TIME[13:0]<br>W ME_SW |             |
| 0      | WBTAC_BBPLL2_STAB CR_WBTAC_BBPLL2_ | Manual mode switch for<br>LE_TIME_SW STABLE_TIME_SW WBTAC_BBPLL2_STABLE_TIME                                    |             |

A2040340 RF WBAC16 RF WBAC STABLE TIME 9 00000000

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24                                                                  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                                               |
|-------|----|----|----|----|----|----|----|---------------------------------------------------------------------|----|----|----|----|----|----|----|--------------------------------------------------|
| Name  |    |    |    |    |    |    |    | WBT<br>AC_B<br>BPLL<br>2_96<br>OM_C<br>K_ST<br>ABLE<br>_TIM<br>E_SW |    |    |    |    |    |    |    | WBT<br>AC_R<br>FDIG<br>_VCO<br>RE_O<br>FF_S<br>W |
| Type  |    |    |    |    |    |    |    | RW                                                                  |    |    |    |    |    |    |    | RW                                               |
| Reset |    |    |    |    |    |    |    | 0                                                                   |    |    |    |    |    |    |    | 0                                                |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8                                                                   | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                                                |
| Name  |    |    |    |    |    |    |    | WBT<br>AC_R<br>FDIG<br>LSF                                          |    |    |    |    |    |    |    | WBT<br>AC_R<br>DY_S<br>TABL                      |

|              |  |  |  |  |  |  |  |                           |  |  |  |  |  |  |                  |
|--------------|--|--|--|--|--|--|--|---------------------------|--|--|--|--|--|--|------------------|
|              |  |  |  |  |  |  |  | <b>LDO<br/>OFF<br/>SW</b> |  |  |  |  |  |  | <b>E_S<br/>W</b> |
| <b>Type</b>  |  |  |  |  |  |  |  | RW                        |  |  |  |  |  |  | RW               |
| <b>Reset</b> |  |  |  |  |  |  |  | 0                         |  |  |  |  |  |  | 0                |

| <b>Bit(s)</b> | <b>Mnemonic</b>                          | <b>Name</b>                                                   | <b>Description</b>               |
|---------------|------------------------------------------|---------------------------------------------------------------|----------------------------------|
| 24            | WBTAC_BBPLL2_96oM_CK CR_WBTAC_BBPLL2_96o | Manual mode switch for<br>_STABLE_TIME_SW M_CK_STABLE_TIME_SW | WBTAC_BBPLL2_96oM_CK_STABLE_TIME |
| 16            | WBTAC_RFDIG_VCORE_OFCR_WBTAC_RFDIG_VCOR  | F_SW E_OFF_TIME_SW                                            | WBTAC_RFDIG_VCORE_OFF_TIME       |
| 8             | WBTAC_RFDIG_LSFLO_O CR_WBTAC_RFDIG_LSF   | FF_SW DO_OFF_TIME_SW                                          | WBTAC_RFDIG_LSFLO_OFF_TIME       |
| 0             | WBTAC_RDY_STABLE_SW CR_WBTAC_RDY_STABLE  | _TIME_SW                                                      | WBTAC_RDY_STABLE_TIME            |

A2040344 RF WBAC17 WBAC MANUAL CONTROL 00000000

| <b>Bit</b>   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24                                                     | 23 | 22 | 21 | 20 | 19 | 18 | 17                                                  | 16 |
|--------------|----|----|----|----|----|----|----|--------------------------------------------------------|----|----|----|----|----|----|-----------------------------------------------------|----|
| <b>Name</b>  |    |    |    |    |    |    |    | <b>SWCT<br/>L_W<br/>BTAC<br/>BT<br/>PLL</b>            |    |    |    |    |    |    | <b>SWC<br/>TL_D<br/>A_EN<br/>WF<br/>BBP<br/>LL1</b> |    |
| <b>Type</b>  |    |    |    |    |    |    |    | RW                                                     |    |    |    |    |    |    | RW                                                  |    |
| <b>Reset</b> |    |    |    |    |    |    |    | 0                                                      |    |    |    |    |    |    | 0                                                   |    |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8                                                      | 7  | 6  | 5  | 4  | 3  | 2  | 1                                                   | 0  |
| <b>Name</b>  |    |    |    |    |    |    |    | <b>SWCT<br/>L_DA<br/>EN<br/>BBPL<br/>L1_C<br/>KDIG</b> |    |    |    |    |    |    | <b>SWC<br/>TL_D<br/>A_EN<br/>WF<br/>BBP<br/>LL2</b> |    |
| <b>Type</b>  |    |    |    |    |    |    |    | RW                                                     |    |    |    |    |    |    | RW                                                  |    |
| <b>Reset</b> |    |    |    |    |    |    |    | 0                                                      |    |    |    |    |    |    | 0                                                   |    |

| <b>Bit(s)</b> | <b>Mnemonic</b>                                                                        | <b>Name</b>                                                                 | <b>Description</b> |
|---------------|----------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|--------------------|
| 24            | SWCTL_WBTAC_BT_PLLCR_SWCTL_WBTAC_BT_PLL                                                | DA_WBTAC_* = SWCTL_WBTAC_*  <br>BP_PLL_DLY ? SW_WBTAC_* :<br>hw_DA_WBTAC_*; |                    |
| 16            | SWCTL_DA_EN_WF_BB CR_SWCTL_DA_EN_WF_BBPLL1                                             | DA_WBTAC_* = SWCTL_WBTAC_*  <br>BP_PLL_DLY ? SW_WBTAC_* :<br>hw_DA_WBTAC_*; |                    |
| 8             | SWCTL_DA_EN_BBPLL1 CR_SWCTL_DA_EN_BBPLL1_CK DA_WBTAC_* = SWCTL_WBTAC_*  <br>_CKDIG DIG | BP_PLL_DLY ? SW_WBTAC_* :<br>hw_DA_WBTAC_*;                                 |                    |
| 0             | SWCTL_DA_EN_WF_BB CR_SWCTL_DA_EN_WF_BBPLL2                                             | DA_WBTAC_* = SWCTL_WBTAC_*  <br>BP_PLL_DLY ? SW_WBTAC_* :<br>hw_DA_WBTAC_*; |                    |

A2040348 RF WBAC18 WBAC MANUAL CONTROL 00000000

| <b>Bit</b> | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
|------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|

|              |    |    |    |    |    |    |                                            |   |   |   |   |   |   |                                         |   |
|--------------|----|----|----|----|----|----|--------------------------------------------|---|---|---|---|---|---|-----------------------------------------|---|
| <b>Name</b>  |    |    |    |    |    |    | <b>SWCTL_DA_EN_BBPLL2_960M_CK</b>          |   |   |   |   |   |   | <b>SWC_TL_D_A_EN_WF_o_RF_DIG_LSFLDO</b> |   |
| <b>Type</b>  |    |    |    |    |    |    | RW                                         |   |   |   |   |   |   | RW                                      |   |
| <b>Reset</b> |    |    |    |    |    |    | 0                                          |   |   |   |   |   |   | 0                                       |   |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9                                          | 8 | 7 | 6 | 5 | 4 | 3 | 2                                       | 1 |
| <b>Name</b>  |    |    |    |    |    |    | <b>SWCTL_DA_EN_WFo_RF_RFDIG_DIG_LSFLDO</b> |   |   |   |   |   |   | <b>SWC_TL_D_A_EN_WF_o_LS_FLDO</b>       |   |
| <b>Type</b>  |    |    |    |    |    |    | RW                                         |   |   |   |   |   |   | RW                                      |   |
| <b>Reset</b> |    |    |    |    |    |    | 0                                          |   |   |   |   |   |   | 0                                       |   |

| <b>Bit(s)</b> | <b>Mnemonic</b>                                        | <b>Name</b> | <b>Description</b>                                                    |
|---------------|--------------------------------------------------------|-------------|-----------------------------------------------------------------------|
| 24            | SWCTL_DA_EN_BBPLL2_CR_SWCTL_DA_EN_BBPLL2_960M_CK       | M_CK        | DA_WBTAC_* = SWCTL_WBTAC_*   BP_PLL_DLY ? SW_WBTAC_* : hw_DA_WBTAC_*; |
| 16            | SWCTL_DA_EN_WFo_RF_CR_SWCTL_DA_EN_WFo_RFDIG_DIG_LSFLDO | _LSFLDO     | DA_WBTAC_* = SWCTL_WBTAC_*   BP_PLL_DLY ? SW_WBTAC_* : hw_DA_WBTAC_*; |
| 8             | SWCTL_DA_EN_WFo_RF_CR_SWCTL_DA_EN_WFo_RFDIG_DIG_VCORE  | _VCORE      | DA_WBTAC_* = SWCTL_WBTAC_*   BP_PLL_DLY ? SW_WBTAC_* : hw_DA_WBTAC_*; |
| 0             | SWCTL_DA_EN_WFo_LS_CR_SWCTL_DA_EN_WFo_LSFLDO           | O           | DA_WBTAC_* = SWCTL_WBTAC_*   BP_PLL_DLY ? SW_WBTAC_* : hw_DA_WBTAC_*; |

| <b>A204034C RF_WBAC19 WBAC MANUAL CONTROL</b> |    |    |    |    |    |    |    |                                        |    |    |    |    |    |    | 00000000                       |    |
|-----------------------------------------------|----|----|----|----|----|----|----|----------------------------------------|----|----|----|----|----|----|--------------------------------|----|
| <b>Bit</b>                                    | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24                                     | 23 | 22 | 21 | 20 | 19 | 18 | 17                             | 16 |
| <b>Name</b>                                   |    |    |    |    |    |    |    | <b>SWCTL_DA_EN_WFo_LSF_LDO_OUT_SEL</b> |    |    |    |    |    |    | <b>SWC_TL_D_A_EN_WF_o_LD_O</b> |    |
| <b>Type</b>                                   |    |    |    |    |    |    |    | RW                                     |    |    |    |    |    |    | RW                             |    |
| <b>Reset</b>                                  |    |    |    |    |    |    |    | 0                                      |    |    |    |    |    |    | 0                              |    |
| <b>Bit</b>                                    | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8                                      | 7  | 6  | 5  | 4  | 3  | 2  | 1                              | 0  |
| <b>Name</b>                                   |    |    |    |    |    |    |    | <b>SWCTL_DA_EN_WFo_BG</b>              |    |    |    |    |    |    | <b>SWC_TL_B_TLDO</b>           |    |
| <b>Type</b>                                   |    |    |    |    |    |    |    | RW                                     |    |    |    |    |    |    | RW                             |    |
| <b>Reset</b>                                  |    |    |    |    |    |    |    | 0                                      |    |    |    |    |    |    | 0                              |    |

| <b>Bit(s)</b> | <b>Mnemonic</b>                                      | <b>Name</b> | <b>Description</b>                                                    |
|---------------|------------------------------------------------------|-------------|-----------------------------------------------------------------------|
| 24            | SWCTL_DA_WFo_LSFLDO_OUCR_SWCTL_DA_WFo_LSFLDO_OUT_SEL | DO_OUT_SEL  | DA_WBTAC_* = SWCTL_WBTAC_*   BP_PLL_DLY ? SW_WBTAC_* : hw_DA_WBTAC_*; |

---

|    |                     |                        |                                                                       |
|----|---------------------|------------------------|-----------------------------------------------------------------------|
|    |                     |                        | hw_DA_WBTAC_*;                                                        |
| 16 | SWCTL_DA_EN_WFo_LDO | CR_SWCTL_DA_EN_WFo_LDO | DA_WBTAC_* = SWCTL_WBTAC_*   BP_PLL_DLY ? SW_WBTAC_* : hw_DA_WBTAC_*; |
| 8  | SWCTL_DA_EN_WFo_BG  | CR_SWCTL_DA_EN_WFo_BG  | DA_WBTAC_* = SWCTL_WBTAC_*   BP_PLL_DLY ? SW_WBTAC_* : hw_DA_WBTAC_*; |
| 0  | SWCTL_BTLDO         | CR_SWCTL_WFo_BTLDO     | DA_WBTAC_* = SWCTL_WBTAC_*   BP_PLL_DLY ? SW_WBTAC_* : hw_DA_WBTAC_*; |

---

A2040350 RF WBAC20 WBAC MANUAL CONTROL 00000000

| Bit          | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24                     | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                           |
|--------------|----|----|----|----|----|----|----|------------------------|----|----|----|----|----|----|----|------------------------------|
| <b>Name</b>  |    |    |    |    |    |    |    | <b>SWCTL_BT_PALDO</b>  |    |    |    |    |    |    |    | <b>SWCTL_DA_EN_WF0_TXDIG</b> |
| <b>Type</b>  |    |    |    |    |    |    |    | RW                     |    |    |    |    |    |    |    | RW                           |
| <b>Reset</b> |    |    |    |    |    |    |    | 0                      |    |    |    |    |    |    |    | 0                            |
| Bit          | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8                      | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                            |
| <b>Name</b>  |    |    |    |    |    |    |    | <b>SW_WBTAC_BT_PLL</b> |    |    |    |    |    |    |    | <b>SW_DA_E_N_W_F_BB_PLL1</b> |
| <b>Type</b>  |    |    |    |    |    |    |    | RW                     |    |    |    |    |    |    |    | RW                           |
| <b>Reset</b> |    |    |    |    |    |    |    | 0                      |    |    |    |    |    |    |    | 0                            |

---

| Bit(s) | Mnemonic              | Name                      | Description                                                           |
|--------|-----------------------|---------------------------|-----------------------------------------------------------------------|
| 24     | SWCTL_BTPALDO         | CR_SWCTL_WFo_BT_PALDO     | DA_WBTAC_* = SWCTL_WBTAC_*   BP_PLL_DLY ? SW_WBTAC_* : hw_DA_WBTAC_*; |
| 16     | SWCTL_DA_EN_WFo_TXDIG | CR_SWCTL_DA_E_N_WFo_TXDIG | DA_WBTAC_* = SWCTL_WBTAC_*   BP_PLL_DLY ? SW_WBTAC_* : hw_DA_WBTAC_*; |
| 8      | SW_WBTAC_BT_PLL       | CR_SW_WBTAC_B_T_PLL       | DA_WBTAC_* = SWCTL_WBTAC_*   BP_PLL_DLY ? SW_WBTAC_* : hw_DA_WBTAC_*; |
| 0      | SW_DA_EN_WF_BBPCR_LL1 | CR_SW_DA_E_N_W_F_BBPLL1   | DA_WBTAC_* = SWCTL_WBTAC_*   BP_PLL_DLY ? SW_WBTAC_* : hw_DA_WBTAC_*; |

---

A2040354 RF WBAC21 WBAC MANUAL CONTROL 00000000

| Bit          | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24                             | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                           |
|--------------|----|----|----|----|----|----|----|--------------------------------|----|----|----|----|----|----|----|------------------------------|
| <b>Name</b>  |    |    |    |    |    |    |    | <b>SW_DA_E_N_BB_PLL1_CKD1G</b> |    |    |    |    |    |    |    | <b>SW_DA_E_N_W_F_BB_PLL2</b> |
| <b>Type</b>  |    |    |    |    |    |    |    | RW                             |    |    |    |    |    |    |    | RW                           |
| <b>Reset</b> |    |    |    |    |    |    |    | 0                              |    |    |    |    |    |    |    | 0                            |
| Bit          | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8                              | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                            |
| <b>Name</b>  |    |    |    |    |    |    |    | <b>SW_DA_E_N_BB_PLL2</b>       |    |    |    |    |    |    |    | <b>SW_DA_E_N_W_Fo_R</b>      |

|              |  |  |  |  |  |  |                          |  |  |  |  |  |  |  |                             |
|--------------|--|--|--|--|--|--|--------------------------|--|--|--|--|--|--|--|-----------------------------|
|              |  |  |  |  |  |  | <b>960<br/>M_C<br/>K</b> |  |  |  |  |  |  |  | <b>FDIG<br/>LSF<br/>LDO</b> |
| <b>Type</b>  |  |  |  |  |  |  | RW                       |  |  |  |  |  |  |  | RW                          |
| <b>Reset</b> |  |  |  |  |  |  | 0                        |  |  |  |  |  |  |  | 0                           |

| <b>Bit(s)</b> | <b>Mnemonic</b>    | <b>Name</b>                                                                                                                         | <b>Description</b> |
|---------------|--------------------|-------------------------------------------------------------------------------------------------------------------------------------|--------------------|
| 24            | SW_DA_EN_BBPLL1    | CR_SW_DA_EN_BBP DA_WBTAC_* = SWCTL_WBTAC_*   BP_PLL_DLY ?<br>_CKDIG LL1_CKDIG SW_WBTAC_* : hw_DA_WBTAC_*;                           |                    |
| 16            | SW_DA_EN_WF_BBPCR  | SW_DA_EN_WF_BBPCR_SW_DA_EN_WF DA_WBTAC_* = SWCTL_WBTAC_*   BP_PLL_DLY ?<br>LL2 _BBPLL2 SW_WBTAC_* : hw_DA_WBTAC_*;                  |                    |
| 8             | SW_DA_EN_BBPLL2    | CR_SW_DA_EN_BBP DA_WBTAC_* = SWCTL_WBTAC_*   BP_PLL_DLY ?<br>_960M_CK LL2_960M_CK SW_WBTAC_* : hw_DA_WBTAC_*;                       |                    |
| 0             | SW_DA_EN_WFo_RFCSR | SW_DA_EN_WFo_RFCSR_SW_DA_EN_WFo DA_WBTAC_* = SWCTL_WBTAC_*   BP_PLL_DLY ?<br>DIG_LSF_LDO _RFDIG_LSF_LDO SW_WBTAC_* : hw_DA_WBTAC_*; |                    |

| A2040358 RF WBAC22 WBAC MANUAL CONTROL 01000000 |    |    |    |    |    |    |                                      |                                                     |    |    |    |    |    |    |                                                |    |
|-------------------------------------------------|----|----|----|----|----|----|--------------------------------------|-----------------------------------------------------|----|----|----|----|----|----|------------------------------------------------|----|
| <b>Bit</b>                                      | 31 | 30 | 29 | 28 | 27 | 26 | 25                                   | 24                                                  | 23 | 22 | 21 | 20 | 19 | 18 | 17                                             | 16 |
| <b>Name</b>                                     |    |    |    |    |    |    |                                      | <b>SW_DA_E<br/>N_W<br/>Fo_R<br/>FDIG_VCO<br/>RE</b> |    |    |    |    |    |    | <b>SW_DA_E<br/>N_W<br/>Fo_L<br/>SFLD<br/>O</b> |    |
| <b>Type</b>                                     |    |    |    |    |    |    |                                      | RW                                                  |    |    |    |    |    |    | RW                                             |    |
| <b>Reset</b>                                    |    |    |    |    |    |    |                                      | 1                                                   |    |    |    |    |    |    | 0                                              |    |
| <b>Bit</b>                                      | 15 | 14 | 13 | 12 | 11 | 10 | 9                                    | 8                                                   | 7  | 6  | 5  | 4  | 3  | 2  | 1                                              | 0  |
| <b>Name</b>                                     |    |    |    |    |    |    | <b>SW_DA_WFo_LS<br/>FLDO_OUT_SEL</b> |                                                     |    |    |    |    |    |    | <b>SW_DA_E<br/>N_W<br/>Fo_L<br/>DO</b>         |    |
| <b>Type</b>                                     |    |    |    |    |    |    | RW                                   |                                                     |    |    |    |    |    |    | RW                                             |    |
| <b>Reset</b>                                    |    |    |    |    |    |    | 0 0 0                                |                                                     |    |    |    |    |    |    | 0                                              |    |

| <b>Bit(s)</b> | <b>Mnemonic</b>                | <b>Name</b>                                                                                      | <b>Description</b> |
|---------------|--------------------------------|--------------------------------------------------------------------------------------------------|--------------------|
| 24            | SW_DA_EN_WFoCR_SW_DA_EN_WFo_R  | DA_WBTAC_* = SWCTL_WBTAC_*   BP_PLL_DLY ?<br>_RFDIG_VCORE FDIG_VCORE SW_WBTAC_* : hw_DA_WBTAC_*; |                    |
| 16            | SW_DA_EN_WFoCR_SW_DA_EN_WFo_L  | DA_WBTAC_* = SWCTL_WBTAC_*   BP_PLL_DLY ?<br>_LSFLDO SFLDO SW_WBTAC_* : hw_DA_WBTAC_*;           |                    |
| 10:8          | SW_DA_WFo_LS CR_SW_DA_WFo_LSFL | DA_WBTAC_* = SWCTL_WBTAC_*   BP_PLL_DLY ?<br>DO_OUT_SEL DO_OUT_SEL SW_WBTAC_* : hw_DA_WBTAC_*;   |                    |
| 0             | SW_DA_EN_WFoCR_SW_DA_EN_WFo_L  | DA_WBTAC_* = SWCTL_WBTAC_*   BP_PLL_DLY ?<br>_LDO DO SW_WBTAC_* : hw_DA_WBTAC_*;                 |                    |

| A204035C RF WBAC23 WBAC MANUAL CONTROL 00000000 |    |    |    |    |    |    |    |                                       |    |    |    |    |    |    |                          |    |
|-------------------------------------------------|----|----|----|----|----|----|----|---------------------------------------|----|----|----|----|----|----|--------------------------|----|
| <b>Bit</b>                                      | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24                                    | 23 | 22 | 21 | 20 | 19 | 18 | 17                       | 16 |
| <b>Name</b>                                     |    |    |    |    |    |    |    | <b>SW_DA_E<br/>N_W<br/>Fo_B<br/>G</b> |    |    |    |    |    |    | <b>SW_WFo_BTL<br/>DO</b> |    |

|       |    |    |    |    |    |    |    |                 |   |   |   |   |   |    |    |                       |
|-------|----|----|----|----|----|----|----|-----------------|---|---|---|---|---|----|----|-----------------------|
| Type  |    |    |    |    |    |    | RW |                 |   |   |   |   |   | RW |    |                       |
| Reset |    |    |    |    |    |    | 0  |                 |   |   |   |   |   | 0  |    |                       |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8               | 7 | 6 | 5 | 4 | 3 | 2  | 1  | 0                     |
| Name  |    |    |    |    |    |    |    | SW_WFo_BT_PALDO |   |   |   |   |   |    |    | SW_DA_E_N_W_Fo_T_XDIG |
| Type  |    |    |    |    |    |    |    | RW              |   |   |   |   |   |    | RW |                       |
| Reset |    |    |    |    |    |    |    | 0               |   |   |   |   |   |    | 0  |                       |

| Bit(s) | Mnemonic                                 | Name                                                                     | Description                                                         |
|--------|------------------------------------------|--------------------------------------------------------------------------|---------------------------------------------------------------------|
| 24     | SW_DA_EN_WFo_B                           | CR_SW_DA_EN_WFoDA_WBTAC_*                                                | = SWCTL_WBTAC_*   BP_PLL_DLY ?<br>G _BG SW_WBTAC_* : hw_DA_WBTAC_*; |
| 16     | SW_WFo_BTLD0                             | CR_SW_WFo_BTLD0DA_WBTAC_*                                                | = SWCTL_WBTAC_*   BP_PLL_DLY ?<br>SW_WBTAC_* : hw_DA_WBTAC_*;       |
| 8      | SW_WFo_BT_PALDO                          | CR_SW_WFo_BT_PA DA_WBTAC_*                                               | = SWCTL_WBTAC_*   BP_PLL_DLY ?<br>LDO SW_WBTAC_* : hw_DA_WBTAC_*;   |
| 0      | SW_DA_EN_WFo_TXCR_SW_DA_EN_WFoDA_WBTAC_* | = SWCTL_WBTAC_*   BP_PLL_DLY ?<br>DIG _TXDIG SW_WBTAC_* : hw_DA_WBTAC_*; |                                                                     |

| A2040360 RF WBAC24 WF_TOP_REG |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 0000019F |  |
|-------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|----------|--|
| <b>Bit</b>                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |
| <b>Name</b>                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |
| <b>Type</b>                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |
| <b>Reset</b>                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |
| <b>Bit</b>                    |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |
| <b>Name</b>                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |
| <b>Type</b>                   |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |
| <b>Reset</b>                  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |

| Bit(s) | Mnemonic  | Name         | Description                      |
|--------|-----------|--------------|----------------------------------|
| 31:0   | RG_WF_TOP | CR_RG_WF_TOP | Wi-Fi top configuration register |

| A2040364 RF WBAC25 WBAC MANUAL CONTROL |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | 00000000 |  |
|----------------------------------------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|----------|--|
| <b>Bit</b>                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |
| <b>Name</b>                            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |
| <b>Type</b>                            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |
| <b>Reset</b>                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |
| <b>Bit</b>                             |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |
| <b>Name</b>                            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |
| <b>Type</b>                            |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |
| <b>Reset</b>                           |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |          |  |

| <b>Bit(s)</b> | <b>Mnemonic</b>                          | <b>Name</b>                                                              | <b>Description</b> |
|---------------|------------------------------------------|--------------------------------------------------------------------------|--------------------|
| 24            | CR_MCU_960_EN                            | CR_MCU_960_EN                                                            | Reserved           |
| 16            | SWCTL_DA_EN_WCR_SWCTL_DA_EN_F_BBPLL1_LDO | DA_WBTAC_* = SWCTL_WBTAC_*   BP_PLL_DLY ?<br>SW_WBTAC_* : hw_DA_WBTAC_*; |                    |
| 8             | SWCTL_DA_EN_WCR_SWCTL_DA_EN_Fo_AFELDO    | DA_WBTAC_* = SWCTL_WBTAC_*   BP_PLL_DLY ?<br>SW_WBTAC_* : hw_DA_WBTAC_*; |                    |
| 0             | SWCTL_DA_EN_WCR_SWCTL_DA_EN_Fo_TRXLDO    | DA_WBTAC_* = SWCTL_WBTAC_*   BP_PLL_DLY ?<br>SW_WBTAC_* : hw_DA_WBTAC_*; |                    |

A2040368 RF WBAC26 WBAC MANUAL CONTROL 00000000

| <b>Bit</b>   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                        |
|--------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------------------|
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | SW_DA_E_N_W_F_BB_PLL1_LDO |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW                        |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0                         |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                         |
| <b>Name</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | SW_DA_E_N_W_Fo_A_FELDO    |
| <b>Type</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW                        |
| <b>Reset</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0                         |

| <b>Bit(s)</b> | <b>Mnemonic</b>         | <b>Name</b>               | <b>Description</b>                                                       |
|---------------|-------------------------|---------------------------|--------------------------------------------------------------------------|
| 16            | SW_DA_EN_WF_BB_PLL1_LDO | CR_SW_DA_EN_WF_BBPLL1_LDO | DA_WBTAC_* = SWCTL_WBTAC_*   BP_PLL_DLY ?<br>SW_WBTAC_* : hw_DA_WBTAC_*; |
| 8             | SW_DA_EN_WFo_A_FELDO    | CR_SW_DA_EN_WFoDA_WBTAC_* | = SWCTL_WBTAC_*   BP_PLL_DLY ?<br>SW_WBTAC_* : hw_DA_WBTAC_*;            |
| 0             | SW_DA_EN_WFo_T_RXLDO    | CR_SW_DA_EN_WFoDA_WBTAC_* | = SWCTL_WBTAC_*   BP_PLL_DLY ?<br>SW_WBTAC_* : hw_DA_WBTAC_*;            |

A2040370 RF WBAC27 WF\_BG\_REG 00492088

| <b>Bit</b>   | 31               | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  | RG_WFo_BG[31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 1  | 0  | 0  | 1  |
| <b>Bit</b>   | 15               | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | RG_WFo_BG[15:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RW               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                | 0  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 1  | 0  | 0  | 0  |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b>  | <b>Description</b>                    |
|---------------|-----------------|--------------|---------------------------------------|
| 31:0          | RG_WFo_BG       | CR_RG_WFo_BG | Wi-Fi band-gap configuration register |

## A2040374 RF\_WBAC28 WBAC MANUAL CONTROL 00000000

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24                           | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                        |
|-------|----|----|----|----|----|----|----|------------------------------|----|----|----|----|----|----|----|---------------------------|
| Name  |    |    |    |    |    |    |    |                              |    |    |    |    |    |    |    |                           |
| Type  |    |    |    |    |    |    |    |                              |    |    |    |    |    |    |    |                           |
| Reset |    |    |    |    |    |    |    |                              |    |    |    |    |    |    |    |                           |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8                            | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                         |
| Name  |    |    |    |    |    |    |    | RG_WFO_L<br>DO_LSF_P<br>WRSV |    |    |    |    |    |    |    | WBT<br>AC_B<br>BPLL<br>SW |
| Type  |    |    |    |    |    |    |    | RW                           |    |    |    |    |    |    |    | RW                        |
| Reset |    |    |    |    |    |    |    | 0 0                          |    |    |    |    |    |    |    | 0                         |

| Bit(s) | Mnemonic                                | Name                                                                                | Description |
|--------|-----------------------------------------|-------------------------------------------------------------------------------------|-------------|
| 9:8    | RG_WFO_LDO_LSF_P CR_RG_WFO_LDO_LSF_PWRS | For saving WFo LDO current                                                          |             |
|        | WRSV V                                  |                                                                                     |             |
| 0      | WBTAC_BBPLL_SW CR_WBTAC_BBPLL_SW        | RG_WF_BBPLL_ox = WBTAC_BBPLL_SW ?<br>RG_WF_BBPLL_ox[31:0] :<br>hw_WF_BBPLL_ox[31:0] |             |

## A2040384 RO\_RF\_WBAC1 RF WBAC RG 1 0811E000

| Bit   | 31                              | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|---------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | RG_WF_BBPLL_01[31:16]           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0 0 0 0 1 0 0 0 0 0 0 0 1 0 0 1 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15                              | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | RG_WF_BBPLL_01[15:0]            |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RO                              |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 1 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| Bit(s) | Mnemonic       | Name           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------|----------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | RG_WF_BBPLL_01 | RG_WF_BBPLL_01 | Wi-Fi PLL registers.<br>Actual<br>RG_WF_BBPLL_01 = WBTAC_BBPLL_SW ?<br>RG_WF_BBPLL_01[31:0] :<br>case(BBPLL1_FREQ_SEL, xtal_freq)<br>5'b01000: BBPLL1=832 MHz, XTAL=52<br>MHz ,32'h45962040<br>5'b00100: BBPLL1=832 MHz, XTAL=40<br>MHz ,32'h01234567<br>5'b00010: BBPLL1=832 MHz, XTAL=26<br>MHz ,32'h45962040<br>5'b00001: BBPLL1=832 MHz, XTAL=20<br>MHz ,32'h01234567<br>5'b11000: BBPLL1=1040 MHz, XTAL=52<br>MHz ,32'h454B2840<br>5'b10100: BBPLL1=1040 MHz, XTAL=40<br>MHz ,32'h454B3440<br>5'b10010: BBPLL1=1040 MHz, XTAL=26<br>MHz ,32'h054B2840<br>5'b10001: BBPLL1=1040 MHz, XTAL=20<br>MHz ,32'h054B3440<br>default : 32'h054B2840 |

---

 endcase
 

---

**A204038    RO RF WB  
8              AC2**
**RF WBAC RG 2****6oC8Eo18**

| <b>Bit</b>   | 31                           | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>  | <b>RG_WF_BBPLL_02[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RO                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                            | 1  | 1  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 0  | 0  | 1  | 0  | 0  | 0  |
| <b>Bit</b>   | 15                           | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>  | <b>RG_WF_BBPLL_02[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>  | RO                           |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 1                            | 1  | 1  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 0  | 0  | 0  |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b>    | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------------|-----------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0          | RG_WF_BBPLL_02  | RG_WF_BBPLL_02 | Wi-Fi PLL registers.<br>Actual<br>RG_WF_BBPLL_02 = WBTAC_BBPLL_SW ?<br>RG_WF_BBPLL_02[31:0] :<br>case(BBPLL1_FREQ_SEL, xtal_freq)<br>5'b01000: BBPLL1=832 MHz, XTAL=52<br>MHz ,32'h05691E40<br>5'b00100: BBPLL1=832 MHz, XTAL=40<br>MHz ,32'h45693040<br>5'b00010: BBPLL1=832 MHz, XTAL=26<br>MHz ,32'h05691E40<br>5'b00001: BBPLL1=832 MHz, XTAL=20<br>MHz ,32'h05693040<br>5'b11000: BBPLL1=1040 MHz, XTAL=52<br>MHz ,32'h05691840<br>5'b10100: BBPLL1=1040 MHz, XTAL=40<br>MHz ,32'h45693040<br>5'b10010: BBPLL1=1040 MHz, XTAL=26<br>MHz ,32'h05691840<br>5'b10001: BBPLL1=1040 MHz, XTAL=20<br>MHz ,32'h05693040<br>default : 32'h05691840<br>endcase |
| <hr/>         |                 |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| <hr/>         |                 |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| <hr/>         |                 |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

**A204038    RO RF WB  
C              AC3**
**RF WBAC STABLE TIME 0****NA**

| <b>Bit</b>   | 31                                    | 30 | 29         | 28         | 27         | 26         | 25         | 24         | 23         | 22         | 21         | 20         | 19         | 18         | 17         | 16 |
|--------------|---------------------------------------|----|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|------------|----|
| <b>Name</b>  | <b>WBTAC_LSFLDO_STABLE_TIME</b>       |    |            |            |            |            |            |            |            |            |            |            |            |            |            |    |
| <b>Type</b>  | RO                                    |    |            |            |            |            |            |            |            |            |            |            |            |            |            |    |
| <b>Reset</b> |                                       |    | 14d<br>260 |    |
| <b>Bit</b>   | 15                                    | 14 | 13         | 12         | 11         | 10         | 9          | 8          | 7          | 6          | 5          | 4          | 3          | 2          | 1          | 0  |
| <b>Name</b>  | <b>WBTAC_RFIDIG_VCORE_STABLE_TIME</b> |    |            |            |            |            |            |            |            |            |            |            |            |            |            |    |
| <b>Type</b>  | RO                                    |    |            |            |            |            |            |            |            |            |            |            |            |            |            |    |
| <b>Reset</b> |                                       |    | 0          | 0          | 0          | 0          | 0          | 1          | 1          | 0          | 0          | 0          | 0          | 1          | 1          | 0  |

| Bit(s) | Mnemonic                                            | Name                              | Description                                                                                                                                                                                                             |
|--------|-----------------------------------------------------|-----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29:16  | WBTAC_LSFLDO_STABLE CR_WBTAC_LSFLDO_S<br>_TIME      | Actual<br>TABLE_TIME_SEL          | WBTAC_LSFLDO_STABLE_TIME[13:0] =<br>WBTAC_LSFLDO_STABLE_TIME_SW ?<br>WBTAC_LSFLDO_STABLE_TIME[13:0] :<br>case(f_fxo_is_26m)<br>1'b1: f_fxo_ck=26 MHz,14'd260<br>1'bo: f_fxo_ck=20 MHz,14'd200<br>endcase                |
| 13:0   | WBTAC_RFDIG_VCORE_S CR_WBTAC_RFDIG_VC<br>TABLE_TIME | Actual<br>ORE_STABLE_TIME_S<br>EL | WBTAC_RFDIG_VCORE_STABLE_TIME[13:0] =<br>WBTAC_RFDIG_VCORE_STABLE_TIME_SW ?<br>WBTAC_RFDIG_VCORE_STABLE_TIME[13:0] :<br>case(f_fxo_is_26m)<br>1'b1: f_fxo_ck=26 MHz,14'd416<br>1'bo: f_fxo_ck=20 MHz,14'd320<br>endcase |

| A204039                                 |    | RO  | RF | WB | RF WBAC STABLE TIME 1 |    |    |    |    |    |    |    |    |    |    |    | 016C01BA |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
|-----------------------------------------|----|-----|----|----|-----------------------|----|----|----|----|----|----|----|----|----|----|----|----------|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|--|
|                                         |    | AC4 |    |    |                       |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Bit</b>                              |    |     |    |    |                       |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Name</b>                             |    |     |    |    |                       |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Type</b>                             |    |     |    |    |                       |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Reset</b>                            |    |     |    |    |                       |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Bit</b>                              | 31 | 30  | 29 | 28 | 27                    | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>WBTAC_RFDIG_LSFLDO_STABLE_TIME</b>   |    |     |    |    |                       |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>RO</b>                               |    |     |    |    |                       |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>0</b>                                | 0  | 0   | 0  | 0  | 0                     | 1  | 0  | 1  | 1  | 0  | 1  | 1  | 0  | 0  | 0  | 0  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>WBTAC_LSFLDO_OUT_SEL_STABLE_TIME</b> |    |     |    |    |                       |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>RO</b>                               |    |     |    |    |                       |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>Reset</b>                            |    |     |    |    |                       |    |    |    |    |    |    |    |    |    |    |    |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| <b>0</b>                                | 0  | 0   | 0  | 0  | 0                     | 1  | 1  | 0  | 1  | 1  | 1  | 0  | 1  | 0  | 1  | 0  |          |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |

| Bit(s) | Mnemonic                                                                       | Name                                                                                                                                                                                                                                       | Description |
|--------|--------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 29:16  | WBTAC_RFDIG_LS CR_WBTAC_RFDIG_LSF<br>FLDO_STABLE_TI LDO_STABLE_TIME_SE<br>ME L | Actual<br>WBTAC_RFDIG_LSFLDO_STABLE_TIME[13:0] =<br>WBTAC_RFDIG_LSFLDO_STABLE_TIME_SW ?<br>WBTAC_RFDIG_LSFLDO_STABLE_TIME[13:0] :<br>case(f_fxo_is_26m)<br>1'b1: f_fxo_ck=26 MHz,14'd312<br>1'bo: f_fxo_ck=20 MHz,14'd240<br>endcase       |             |
| 13:0   | WBTAC_LSFLDO_ OUT_SEL_STABLE_UT_SEL_STABLE_TIME<br>_TIME _SEL                  | Actual<br>WBTAC_LSFLDO_OUT_SEL_STABLE_TIME[13:0] =<br>WBTAC_LSFLDO_OUT_SEL_STABLE_TIME_SW ?<br>WBTAC_LSFLDO_OUT_SEL_STABLE_TIME[13:0] :<br>case(f_fxo_is_26m)<br>1'b1: f_fxo_ck=26 MHz,14'd468<br>1'bo: f_fxo_ck=20 MHz,14'd360<br>endcase |             |

**A2040394 RO RF WB  
AC5**

**RF WBAC STABLE TIME 2**

**01EE03F6**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 0  | 1  | 1  | 0  |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | 1  | 0  | 1  | 0  |

| Bit(s) | Mnemonic                  | Name                                   | Description                                                                                                                                                                            |
|--------|---------------------------|----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29:16  | WBTAC_LDO_STABLE_ TIME    | CR_WBTAC_LDO_STABLE_ Actual TIME_SEL   | WBTAC_LDO_STABLE_TIME[13:0] = WBTAC_LDO_STABLE_TIME_SW ? WBTAC_LDO_STABLE_TIME[13:0] : case(f_fxo_is_26m) 1'b1: f_fxo_ck=26 MHz,14'd494 1'bo: f_fxo_ck=20 MHz,14'd380 endcase          |
| 13:0   | WBTAC_BBPLL1_STABL E_TIME | CR_WBTAC_BBPLL1_STABLActual E_TIME_SEL | WBTAC_BBPLL1_STABLE_TIME[13:0] = WBTAC_BBPLL1_STABLE_TIME_SW ? WBTAC_BBPLL1_STABLE_TIME[13:0] : case(f_fxo_is_26m) 1'b1: f_fxo_ck=26 MHz,14'd520 1'bo: f_fxo_ck=20 MHz,14'd400 endcase |

**A204039 RO RF WB  
8 AC6**

**RF WBAC STABLE TIME 3**

**090A090A**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    | 0  | 0  | 1  | 0  | 0  | 1  | 0  | 0  | 0  | 0  | 1  | 0  |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    | 0  | 0  | 1  | 0  | 0  | 1  | 0  | 0  | 0  | 0  | 1  | 0  |

| Bit(s) | Mnemonic                  | Name                                    | Description                                                                                                                                                                             |
|--------|---------------------------|-----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 29:16  | WBTAC_BBPLL2_S TABLE_TIME | CR_WBTAC_BBPLL2_STABLE_ Actual TIME_SEL | WBTAC_BBPLL2_STABLE_TIME[13:0] = WBTAC_BBPLL2_STABLE_TIME_SW ? WBTAC_BBPLL2_STABLE_TIME[13:0] : case(f_fxo_is_26m) 1'b1: f_fxo_ck=26 MHz,14'd1820 1'bo: f_fxo_ck=20 MHz,14'd400 endcase |

```

13:0 WBTAC_BBPLL1_C CR_WBTAC_BBPLL1_CKDIG_S Actual
      KDIG_STABLE_TI TABLE_TIME_SEL
      ME
      WBTAC_BBPLL1_CKDIG_STABLE_TIME[13:0] =
      WBTAC_BBPLL1_CKDIG_STABLE_TIME_SW ?
      WBTAC_BBPLL1_CKDIG_STABLE_TIME[13:0] :
      case(f_fxo_is_26m)
        1'b1: f_fxo_ck=26 MHz ,14'd1820
        1'bo: f_fxo_ck=20 MHz ,14'd1400
      endcase

```

| A204039 |     | RO | RF | WB | RF WBAC STABLE TIME 4 |    |    |    |    |    |    |    |    |    |    |    | oF3Coo34 |                                  |
|---------|-----|----|----|----|-----------------------|----|----|----|----|----|----|----|----|----|----|----|----------|----------------------------------|
| C       | AC7 |    |    |    |                       |    |    |    |    |    |    |    |    |    |    |    |          |                                  |
| Bit     | 31  | 30 | 29 | 28 | 27                    | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |          |                                  |
| Name    |     |    |    |    |                       |    |    |    |    |    |    |    |    |    |    |    |          | WBTAC_BBPLL2_960M_CK_STABLE_TIME |
| Type    |     |    |    |    |                       |    |    |    |    |    |    |    |    |    |    |    |          | RO                               |
| Reset   |     |    | 0  | 0  | 1                     | 1  | 1  | 1  | 0  | 0  | 1  | 1  | 1  | 1  | 0  | 0  |          |                                  |
| Bit     | 15  | 14 | 13 | 12 | 11                    | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |          |                                  |
| Name    |     |    |    |    |                       |    |    |    |    |    |    |    |    |    |    |    |          | WBTAC_RFDIG_VCORE_OFF_TIME       |
| Type    |     |    |    |    |                       |    |    |    |    |    |    |    |    |    |    |    |          | RO                               |
| Reset   |     |    |    |    |                       |    |    |    |    |    |    | 0  | 0  | 0  | 1  | 1  | 0        | 0                                |

| Bit(s) | Mnemonic                                 | Name                                                                                                                                                                                                               | Description |
|--------|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| 29:16  | WBTAC_BBPLL2_96oM_CR_WBTAC_BBPLL2        | Actual                                                                                                                                                                                                             |             |
|        | CK_STABLE_TIME _96oM_CK_STABLE _TIME_SEL | WBTAC_BBPLL2_96oM_CK_STABLE_TIME[13:0] = WBTAC_BBPLL2_96oM_CK_STABLE_TIME_SW ? WBTAC_BBPLL2_96oM_CK_STABLE_TIME[13:0] : case(f_fxo_is_26m) 1'b1: f_fxo_ck=26 MHz ,14'd1300 1'bo: f_fxo_ck=20 MHz ,14'd1000 endcase |             |
| 8:0    | WBTAC_RFDIG_VCORE_CR_WBTAC_RFDIG_Actual  |                                                                                                                                                                                                                    |             |
|        | OFF_TIME VCORE_OFF_TIME SEL              | WBTAC_RFDIG_VCORE_OFF_TIME[8:0] = WBTAC_RFDIG_VCORE_OFF_TIME_SW ? WBTAC_RFDIG_VCORE_OFF_TIME[8:0] : case(f_fxo_is_26m) 1'b1: f_fxo_ck=26 MHz ,9'd78 1'bo: f_fxo_ck=20 MHz ,9'd60 endcase                           |             |

|                |            |           |           |                              |    |    |    |                                    |    |    |    |    |    |                 |    |    |   |
|----------------|------------|-----------|-----------|------------------------------|----|----|----|------------------------------------|----|----|----|----|----|-----------------|----|----|---|
| <b>A20403A</b> | <b>RO</b>  | <b>RF</b> | <b>WB</b> | <b>RF WBAC STABLE TIME 5</b> |    |    |    |                                    |    |    |    |    |    | <b>0068001A</b> |    |    |   |
| <b>O</b>       | <b>AC8</b> |           |           |                              |    |    |    |                                    |    |    |    |    |    |                 |    |    |   |
| <b>Bit</b>     | 31         | 30        | 29        | 28                           | 27 | 26 | 25 | 24                                 | 23 | 22 | 21 | 20 | 19 | 18              | 17 | 16 |   |
| <b>Name</b>    |            |           |           |                              |    |    |    | <b>WBTAC_RFDIG_LSFLDO_OFF_TIME</b> |    |    |    |    |    |                 |    |    |   |
| <b>Type</b>    |            |           |           |                              |    |    |    | <b>RO</b>                          |    |    |    |    |    |                 |    |    |   |
| <b>Reset</b>   |            |           |           |                              |    |    |    | 0                                  | 0  | 1  | 1  | 0  | 1  | 0               | 0  | 0  | 0 |
| <b>Bit</b>     | 15         | 14        | 13        | 12                           | 11 | 10 | 9  | 8                                  | 7  | 6  | 5  | 4  | 3  | 2               | 1  | 0  |   |
| <b>Name</b>    |            |           |           |                              |    |    |    | <b>WBTAC_RDY_STABLE_TIME</b>       |    |    |    |    |    |                 |    |    |   |
| <b>Type</b>    |            |           |           |                              |    |    |    | <b>RO</b>                          |    |    |    |    |    |                 |    |    |   |
| <b>Reset</b>   |            |           |           |                              |    |    |    | 0                                  | 0  | 0  | 0  | 1  | 1  | 0               | 1  | 0  |   |

| Bit(s) | Mnemonic            | Name                       | Description                                                                                                                                                                                                     |
|--------|---------------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24:16  | WBTAC_RFDIG_LSFLDO_ | CR_WBTAC_RFDIG_LSFL Actual |                                                                                                                                                                                                                 |
|        | OFF_TIME            | DO_OFF_TIME_SEL            | WBTAC_RFDIG_LSFLDO_OFF_TIME[8:0] =<br>WBTAC_RFDIG_LSFLDO_OFF_TIME_SW ?<br>WBTAC_RFDIG_LSFLDO_OFF_TIME[8:0] :<br>case(f_fxo_is_26m)<br>1'b1: f_fxo_ck=26 MHz ,9'd130<br>1'bo: f_fxo_ck=20 MHz ,9'd100<br>endcase |
| 8:0    | WBTAC_RDY_STABLE_TI | CR_WBTAC_RDY_STABLEActual  |                                                                                                                                                                                                                 |
|        | ME                  | _TIME_SEL                  | WBTAC_RDY_STABLE_TIME[8:0] =<br>WBTAC_RDY_STABLE_TIME_SW ?<br>WBTAC_RDY_STABLE_TIME[8:0] :<br>case(f_fxo_is_26m)<br>1'b1: f_fxo_ck=26 MHz ,9'd26<br>1'bo: f_fxo_ck=20 MHz ,9'd20<br>endcase                     |

| A204040      BBPLL DBG PROB |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | DEBUG PROB    |                |   |   | 00000000 |  |  |  |
|-----------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------|----------------|---|---|----------|--|--|--|
| Bit                         | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            | BBPLL_DBG_PROB |   |   |          |  |  |  |
| Name                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RO            |                |   |   |          |  |  |  |
| Type                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0             | 0              | 0 | 0 |          |  |  |  |
| Reset                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | BBPLL_DBG_SEL |                |   |   |          |  |  |  |
| Bit                         | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0             | RW             |   |   |          |  |  |  |
| Name                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | BBPLL_DBG_SEL |                |   |   |          |  |  |  |
| Type                        |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW            |                |   |   |          |  |  |  |
| Reset                       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 0             | 0              | 0 | 0 |          |  |  |  |

| Bit(s) | Mnemonic       | Name           | Description             |
|--------|----------------|----------------|-------------------------|
| 19:16  | BBPLL_DBG_PROB | BBPLL_DBG_PROB | Debug monitor           |
| 3:0    | BBPLL_DBG_SEL  | BBPLL_DBG_SEL  | Debug monitor selection |

| A2040410      BBPLL RDY |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | BBPLL Ready Status |      |  |  | 00000000 |  |  |  |
|-------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|--------------------|------|--|--|----------|--|--|--|
| Bit                     | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                 | BBPL |  |  |          |  |  |  |
| Name                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    | L2   |  |  |          |  |  |  |
| Type                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    | R    |  |  |          |  |  |  |
| Reset                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    | DY   |  |  |          |  |  |  |
| Bit                     | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                  | BBPL |  |  |          |  |  |  |
| Name                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    | L1   |  |  |          |  |  |  |
| Type                    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    | RD   |  |  |          |  |  |  |
| Reset                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                    | Y    |  |  |          |  |  |  |

| Bit(s) | Mnemonic | Name | Description |
|--------|----------|------|-------------|
|        |          |      |             |

|   |            |            |                                   |
|---|------------|------------|-----------------------------------|
| 8 | BBPLL2_RDY | BBPLL2_RDY | Hardware mode BBPLL2 ready status |
| 0 | BBPLL1_RDY | BBPLL1_RDY | Hardware mode BBPLL1 ready status |

| <b>A204070 PLLTD CON</b> |          | <b>PLLTD Control Register o</b> |    |    |    |    |    |                               |    |    |    |    |    |    |    |    | <b>oooooooo</b>          |  |
|--------------------------|----------|---------------------------------|----|----|----|----|----|-------------------------------|----|----|----|----|----|----|----|----|--------------------------|--|
| <b>o</b>                 | <b>o</b> | 31                              | 30 | 29 | 28 | 27 | 26 | 25                            | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                       |  |
| Name                     |          |                                 |    |    |    |    |    |                               |    |    |    |    |    |    |    |    |                          |  |
| Type                     |          |                                 |    |    |    |    |    |                               |    |    |    |    |    |    |    |    |                          |  |
| Reset                    |          |                                 |    |    |    |    |    |                               |    |    |    |    |    |    |    |    |                          |  |
| Bit                      | 15       | 14                              | 13 | 12 | 11 | 10 | 9  | 8                             | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |                          |  |
| Name                     |          |                                 |    |    |    |    |    | BP<br>C<br>PU<br>C<br>TR<br>L |    |    |    |    |    |    |    |    | BP<br>P<br>LL<br>D<br>LY |  |
| Type                     |          |                                 |    |    |    |    |    | RW                            |    |    |    |    |    |    |    |    | RW                       |  |
| Reset                    |          |                                 |    |    |    |    |    | o                             |    |    |    |    |    |    |    |    | o                        |  |

**Overview****Selects control path of PLL power on sequence**

| Bit(s) | Mnemonic    | Name        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|--------|-------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8      | BP_CPU_CTRL | BP_CPU_CTRL | Selects control path of PLL SW setting <ul style="list-style-type: none"> <li>0: Controlled by CPU</li> <li>1: Controlled by SPM</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0      | BP_PLL_DLY  | BP_PLL_DLY  | Selects control path of PLL power on sequence in normal mode.<br>Automation delay control uses counter to create PLL power on sequence. RG_xPLL_EN is configured in the software, the other signals required for PLL power on sequence could be created by hardware.<br>If PLLx_EN_SEL is set to 0, then PLL will be turned off when PLL_OFF of DPM (Dynamic PLL Management) is 1 even though register RG_xPLL_EN is kept 1. <ul style="list-style-type: none"> <li>0: Controlled by automation delay control</li> <li>1: Controlled by software configuration</li> </ul> |

**22.2.2. cksys\_xo\_clk register map****Module name: cksys\_xo\_clk Base address: (+A2030000h)**

| Address  | Name          | Width | Register Function                                                 |
|----------|---------------|-------|-------------------------------------------------------------------|
| A2030B00 | XO_PDN_CO_NDo | 32    | <b>Clock gating control 0</b>                                     |
| A2030B10 | XO_PDN_SET_Do | 32    | <b>Clock gating set 0</b>                                         |
| A2030B20 | XO_PDN_CL_RDo | 32    | <b>Clock gating clear 0</b>                                       |
| A2030C00 | XO_DCM_CO_N_o | 32    | <b>XO domain clock DCM 0</b><br>XO domain clock DCM configuration |
| A2030C04 | XO_DCM_CO     | 32    | <b>XO domain clock DCM 1</b>                                      |

**Module name:** cksys\_xo\_clk **Base address:** (+A2030000h)

|                |            |               |                               |                                   |    |    |    |    |    |    |    |    |    |    |    |    |                     |
|----------------|------------|---------------|-------------------------------|-----------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|---------------------|
|                | N          | 1             |                               | XO domain clock DCM configuration |    |    |    |    |    |    |    |    |    |    |    |    |                     |
| <b>A2030Bo</b> | <b>XO</b>  | <b>PDN CO</b> | <b>Clock gating control o</b> | <b>0000FFFF</b>                   |    |    |    |    |    |    |    |    |    |    |    |    |                     |
| <b>o</b>       | <b>NDo</b> |               |                               |                                   |    |    |    |    |    |    |    |    |    |    |    |    |                     |
| <b>Bit</b>     | 31         | 30            | 29                            | 28                                | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |                     |
| <b>Mne</b>     |            |               |                               |                                   |    |    |    |    |    |    |    |    |    |    |    |    | XO_PDN_COND0[31:16] |
| <b>Type</b>    |            |               |                               |                                   |    |    |    |    |    |    |    |    |    |    |    |    | RO                  |
| <b>Reset</b>   | 0          | 0             | 0                             | 0                                 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                   |
| <b>Bit</b>     | 15         | 14            | 13                            | 12                                | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |                     |
| <b>Mne</b>     |            |               |                               |                                   |    |    |    |    |    |    |    |    |    |    |    |    | XO_PDN_COND0[15:0]  |
| <b>Type</b>    |            |               |                               |                                   |    |    |    |    |    |    |    |    |    |    |    |    | RO                  |
| <b>Reset</b>   | 1          | 1             | 1                             | 1                                 | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1                   |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b>           | <b>Description</b>             |
|---------------|-----------------|-----------------------|--------------------------------|
| 31:0          |                 | XO_PDN_COND0          | Indicates clock on/off status. |
|               |                 | 21 RG_SW_AUXADC(CG)   |                                |
|               |                 | 20 RSV_20             |                                |
|               |                 | 19 RG_SW_SEJ(CG)      |                                |
|               |                 | 18 RG_SW_EFUSE(CG)    |                                |
|               |                 | 17 RG_SW_GPTIMER(CG)  |                                |
|               |                 | 16 RG_SW_SPM(CG)      |                                |
|               |                 | 9 RG_SW_PWM5(CG)      |                                |
|               |                 | 8 RG_SW_PWM4(CG)      |                                |
|               |                 | 7 RG_SW_PWM3(CG)      |                                |
|               |                 | 6 RG_SW_PWM2(CG)      |                                |
|               |                 | 5 RG_SW_PWM1(CG)      |                                |
|               |                 | 4 RG_SW_PWM0(CG)      |                                |
|               |                 | 3 RSV_3               |                                |
|               |                 | 2 RSV_2               |                                |
|               |                 | 1 RSV_1               |                                |
|               |                 | 0 RG_SW_BBPLL(CG)     |                                |
|               |                 | 0: Clock is turned on |                                |
|               |                 | 1: Clock is gated off |                                |

|                 |           |               |                           |                 |    |    |    |    |    |    |    |    |    |    |    |    |                     |
|-----------------|-----------|---------------|---------------------------|-----------------|----|----|----|----|----|----|----|----|----|----|----|----|---------------------|
| <b>A2030B10</b> | <b>XO</b> | <b>PDN SE</b> | <b>Clock gating set o</b> | <b>00000000</b> |    |    |    |    |    |    |    |    |    |    |    |    |                     |
|                 |           | <b>TDo</b>    |                           |                 |    |    |    |    |    |    |    |    |    |    |    |    |                     |
| <b>Bit</b>      | 31        | 30            | 29                        | 28              | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |                     |
| <b>Mne</b>      |           |               |                           |                 |    |    |    |    |    |    |    |    |    |    |    |    | XO_PDN_SETD0[31:16] |
| <b>Type</b>     |           |               |                           |                 |    |    |    |    |    |    |    |    |    |    |    |    | WO                  |
| <b>Reset</b>    | 0         | 0             | 0                         | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                   |
| <b>Bit</b>      | 15        | 14            | 13                        | 12              | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |                     |
| <b>Mne</b>      |           |               |                           |                 |    |    |    |    |    |    |    |    |    |    |    |    | XO_PDN_SETD0[15:0]  |
| <b>Type</b>     |           |               |                           |                 |    |    |    |    |    |    |    |    |    |    |    |    | WO                  |
| <b>Reset</b>    | 0         | 0             | 0                         | 0               | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                   |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b>          | <b>Description</b>                      |
|---------------|-----------------|----------------------|-----------------------------------------|
| 31:0          |                 | XO_PDN_SETD0         | Write 1 to set up clock gating control. |
|               |                 | 21 RG_SW_AUXADC(CG)  |                                         |
|               |                 | 20 RSV_20            |                                         |
|               |                 | 19 RG_SW_SEJ(CG)     |                                         |
|               |                 | 18 RG_SW_EFUSE(CG)   |                                         |
|               |                 | 17 RG_SW_GPTIMER(CG) |                                         |

16 RG\_SW\_SPM(CG)  
 9 RG\_SW\_PWM5(CG)  
 8 RG\_SW\_PWM4(CG)  
 7 RG\_SW\_PWM3(CG)  
 6 RG\_SW\_PWM2(CG)  
 5 RG\_SW\_PWM1(CG)  
 4 RG\_SW\_PWM0(CG)  
 3 RSV\_3  
 2 RSV\_2  
 1 RSV\_1  
 0 RG\_SW\_BBPLL(CG)  
 0: No active  
 1: To turn off clock

**A2030B2    XO PDN CL  
o                RDo**

Clock gating clear o

oooooooooooo

| Bit   | 31                         | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Mne   | <u>XO_PDN_CLRDo[31:16]</u> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | WO                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15                         | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Mne   | <u>XO_PDN_CLRDo[15:0]</u>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | WO                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                          | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**A2030Co    XO DCM C  
o                ON o**

XO domain clock dcm o

oooooooooooo

| Bit  | 31                  | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|---------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name | <u>RG_XO_DCM_EN</u> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**A2030Co    XO\_DCM\_C  
0            ON\_0**
**XO domain clock dcm\_0****00000002**

| Type         |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  | <b>DB_C_EN</b>     |
|--------------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|--|--|--|--|--|--|--|--------------------|
| <b>Reset</b> |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  | RW                 |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |  |  |  |  | 0                  |
| <b>Name</b>  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  | <b>RG_XO_SFSEL</b> |
| <b>Type</b>  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |  |  |  |  |  |  |  | RW                 |
| <b>Reset</b> |    |    |    |    | 0  | 0  | 0 | 0 | 0 |   | 0 | 0 | 0 | 0 | 1 | 0 |  |  |  |  |  |  |  |                    |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b>       | <b>Description</b>                                                                                                                                                                                                                                 |
|---------------|-----------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27:24         |                 | RG_XO_DCM_EN      | Infra sub-block DCM <ul style="list-style-type: none"> <li>• 0: Disable</li> <li>• 1: Enable</li> </ul>                                                                                                                                            |
| 16            |                 | RG_XO_DCM_DBC_EN  | Infra XO DCM debounce <ul style="list-style-type: none"> <li>• 0: Disable</li> <li>• 1: Enable</li> </ul>                                                                                                                                          |
| 12:8          |                 | RG_XO_DCM_DBC_NUM | Infra XO DCM debounce number <ul style="list-style-type: none"> <li>• 0: Disable</li> <li>• 1: Enable</li> </ul>                                                                                                                                   |
| 5:0           |                 | RG_XO_SFSEL       | Select how to divide the infra XO DCM idle clock frequency <ul style="list-style-type: none"> <li>100000: /1</li> <li>010000: /2</li> <li>001000: /4</li> <li>000100: /8</li> <li>000010: /16</li> <li>000001: /32</li> <li>000000: /64</li> </ul> |

**A2030Co    XO\_DCM\_C  
4            ON\_1**
**XO domain clock dcm\_1****00000000**

| <b>Bit</b>   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24                        | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |  |  |  |  |  |  |  |                                |    |
|--------------|----|----|----|----|----|----|----|---------------------------|----|----|----|----|----|----|----|----|--|--|--|--|--|--|--|--------------------------------|----|
| <b>Name</b>  |    |    |    |    |    |    |    | RG_X_O_FO_RC_E_CL_KS_LO_W |    |    |    |    |    |    |    |    |  |  |  |  |  |  |  | <b>RG_X_O_FO_RC_E_CL_KO_FF</b> |    |
| <b>Type</b>  |    |    |    |    |    |    |    | RW                        |    |    |    |    |    |    |    |    |  |  |  |  |  |  |  |                                | RW |
| <b>Reset</b> |    |    |    |    |    |    |    | 0                         |    |    |    |    |    |    |    |    |  |  |  |  |  |  |  |                                | 0  |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8                         | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |  |  |  |  |  |  |  |                                |    |
| <b>Name</b>  |    |    |    |    |    |    |    | RG_X_O_CL_KS              |    |    |    |    |    |    |    |    |  |  |  |  |  |  |  | <b>RG_X_O_CL_KO</b>            |    |

**A203oCo    XO\_DCM\_C  
4            ON\_1**

**XO domain clock dcm 1**

**oooooooooo**

|              |  |  |  |  |  |  |  |                |  |  |  |  |  |  |  |  |               |
|--------------|--|--|--|--|--|--|--|----------------|--|--|--|--|--|--|--|--|---------------|
|              |  |  |  |  |  |  |  | <b>LO_W_EN</b> |  |  |  |  |  |  |  |  | <b>FF_E_N</b> |
| <b>Type</b>  |  |  |  |  |  |  |  | RW             |  |  |  |  |  |  |  |  | RW            |
| <b>Reset</b> |  |  |  |  |  |  |  | 0              |  |  |  |  |  |  |  |  | 0             |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b>         | <b>Description</b>                                                                                                |
|---------------|-----------------|---------------------|-------------------------------------------------------------------------------------------------------------------|
| 24            |                 | RG_XO_FORCE_CLKSLOW | Infra XO DCM force clock slow <ul style="list-style-type: none"> <li>• 0: Disable</li> <li>• 1: Enable</li> </ul> |
| 16            |                 | RG_XO_FORCE_CLKOFF  | Infra XO DCM force clock off <ul style="list-style-type: none"> <li>• 0: Disable</li> <li>• 1: Enable</li> </ul>  |
| 8             |                 | RG_XO_CLKSLOW_EN    | Infra XO DCM clock slow en <ul style="list-style-type: none"> <li>• 0: Disable</li> <li>• 1: Enable</li> </ul>    |
| 0             |                 | RG_XO_CLKOFF_EN     | Infra XO DCM clock off en <ul style="list-style-type: none"> <li>• 0: Disable</li> <li>• 1: Enable</li> </ul>     |

### 22.2.3. cksys\_bus\_clk register map

**Module name: cksys\_bus\_clk Base address: (+A21D0000h)**

| <b>Address</b> | <b>Name</b>                  | <b>Width</b> | <b>Register Function</b>                                                          |
|----------------|------------------------------|--------------|-----------------------------------------------------------------------------------|
| A21D0100       | <b>BUS_DCM_C<br/>ON_0</b>    | 32           | <b>Bus domain clock DCM 0</b><br>Bus domain clock DCM configuration               |
| A21D0104       | <b>BUS_DCM_C<br/>ON_1</b>    | 32           | <b>Bus domain clock DCM 1</b><br>Bus domain clock DCM configuration               |
| A21D0110       | <b>CM4_DCM_C<br/>ON_0</b>    | 32           | <b>Cortex-M4 domain clock DCM 0</b><br>Cortex-M4 domain clock DCM configuration   |
| A21D0114       | <b>CM4_DCM_C<br/>ON_1</b>    | 32           | <b>Cortex-M4 domain clock DCM 1</b><br>Cortex-M4 domain clock DCM configuration   |
| A21D0130       | <b>SYS_FREE_D<br/>CM_CON</b> | 32           | <b>CM domain free run clock DCM</b><br>CM domain free run clock DCM configuration |
| A21D0140       | <b>SFC_DCM_CO<br/>N_0</b>    | 32           | <b>SFC domain clock DCM 0</b><br>SFC domain clock DCM configuration               |
| A21D0144       | <b>SFC_DCM_CO<br/>N_1</b>    | 32           | <b>SFC domain clock DCM 1</b><br>SFC domain clock DCM configuration               |
| A21D0170       | <b>CLK_FREQ_S<br/>WCH</b>    | 32           | <b>Clock Switch register</b><br>Frequency configuration of normal mode            |
| A21D0300       | <b>PDN_COND0</b>             | 32           | <b>Clock gating control 0</b>                                                     |
| A21D0310       | <b>PDN_SETDo</b>             | 32           | <b>Clock gating set 0</b>                                                         |
| A21D0320       | <b>PDN_CLRDo</b>             | 32           | <b>Clock gating clear 0</b>                                                       |

**A21D0100    BUS\_DCM\_C  
ON\_0            bus domain clock DCM 0            oooooooooo**

| <b>A21D0100    BUS DCM C<br/>ON o</b> |    |    |                    |    |               |    |    |    |              |    |    |    |           |    | <b>bus domain clock DCM o</b>                     |    |  |  | <b>oooooooooooo</b> |  |  |  |  |
|---------------------------------------|----|----|--------------------|----|---------------|----|----|----|--------------|----|----|----|-----------|----|---------------------------------------------------|----|--|--|---------------------|--|--|--|--|
| <b>Bit</b>                            | 31 | 30 | 29                 | 28 | 27            | 26 | 25 | 24 | 23           | 22 | 21 | 20 | 19        | 18 | 17                                                | 16 |  |  |                     |  |  |  |  |
| <b>Name</b>                           |    |    |                    |    | RG_BUS_DCM_EN |    |    |    |              |    |    |    |           |    | RG<br>_B<br>US<br>_D<br>CM<br>_D<br>BC<br>_E<br>N |    |  |  |                     |  |  |  |  |
| <b>Type</b>                           |    |    |                    |    | RW            |    |    |    |              |    |    |    |           |    | RW                                                |    |  |  |                     |  |  |  |  |
| <b>Reset</b>                          |    |    |                    |    | 0 0 0 0       |    |    |    |              |    |    |    |           |    | 0                                                 |    |  |  |                     |  |  |  |  |
| <b>Bit</b>                            | 15 | 14 | 13                 | 12 | 11            | 10 | 9  | 8  | 7            | 6  | 5  | 4  | 3         | 2  | 1                                                 | 0  |  |  |                     |  |  |  |  |
| <b>Name</b>                           |    |    | RG_BUS_DCM_DBC_NUM |    |               |    |    |    | RG_BUS_SFSEL |    |    |    |           |    |                                                   |    |  |  |                     |  |  |  |  |
| <b>Type</b>                           |    |    | RW                 |    |               |    |    |    | RW           |    |    |    |           |    |                                                   |    |  |  |                     |  |  |  |  |
| <b>Reset</b>                          |    |    | 0 0 0 0 0          |    |               |    |    |    | 0 0 0 0 0    |    |    |    | 0 0 0 0 0 |    | 0 0 0 0 0                                         |    |  |  |                     |  |  |  |  |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b>        | <b>Description</b>                                                                                                                                                                                                          |
|---------------|-----------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 27:24         |                 | RG_BUS_DCM_EN      | Infra sub block DCM disable enable <ul style="list-style-type: none"> <li>• 0: Disable</li> <li>• 1: Enable</li> </ul>                                                                                                      |
| 16            |                 | RG_BUS_DCM_DBC_EN  | Infra bus DCM debounce enable <ul style="list-style-type: none"> <li>• 0: Disable</li> <li>• 1: Enable</li> </ul>                                                                                                           |
| 12:8          |                 | RG_BUS_DCM_DBC_NUM | Infra bus DCM debounce number <ul style="list-style-type: none"> <li>• 0: Disable</li> <li>• 1: Enable</li> </ul>                                                                                                           |
| 5:0           |                 | RG_BUS_SFSEL       | Infra bus DCM idle divide selection <ul style="list-style-type: none"> <li>100000: /1</li> <li>010000: /2</li> <li>001000: /4</li> <li>000100: /8</li> <li>000010: /16</li> <li>000001: /32</li> <li>000000: /64</li> </ul> |

| <b>A21D0104    BUS DCM C<br/>ON 1</b> |    |    |    |    |                                                          |    |    |    |    |    |    |    |    |    | <b>bus domain clock dcm 1</b>                           |    |  |  | <b>oooooooooooo</b> |  |  |  |  |
|---------------------------------------|----|----|----|----|----------------------------------------------------------|----|----|----|----|----|----|----|----|----|---------------------------------------------------------|----|--|--|---------------------|--|--|--|--|
| <b>Bit</b>                            | 31 | 30 | 29 | 28 | 27                                                       | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17                                                      | 16 |  |  |                     |  |  |  |  |
| <b>Name</b>                           |    |    |    |    | RG<br>_B<br>US<br>_F<br>OR<br>CE<br>_C<br>LK<br>SL<br>OW |    |    |    |    |    |    |    |    |    | RG<br>_B<br>US<br>_F<br>OR<br>CE<br>_C<br>LK<br>OF<br>F |    |  |  |                     |  |  |  |  |
| <b>Type</b>                           |    |    |    |    | RW                                                       |    |    |    |    |    |    |    |    |    | RW                                                      |    |  |  |                     |  |  |  |  |
| <b>Reset</b>                          |    |    |    |    | 0                                                        |    |    |    |    |    |    |    |    |    | 0                                                       |    |  |  |                     |  |  |  |  |
| <b>Bit</b>                            | 15 | 14 | 13 | 12 | 11                                                       | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1                                                       | 0  |  |  |                     |  |  |  |  |

**A21Do104    BUS DCM C  
ON 1****bus domain clock dcm 1****oooooooooo**

| Name  | RG_B | RG_US | RG_C | RG_LK | RG_SL | RG_OW | RG_E | RG_N | RG_B | RG_US | RG_C | RG_LK | RG_OF | RG_F | RG_EN |
|-------|------|-------|------|-------|-------|-------|------|------|------|-------|------|-------|-------|------|-------|
| Type  | RW   |       |      |       |       |       |      |      | RW   |       |      |       |       |      |       |
| Reset | o    |       |      |       |       |       |      |      | o    |       |      |       |       |      |       |

| Bit(s) | Mnemonic | Name                 | Description                                                                                                                                                   |
|--------|----------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 24     |          | RG_BUS_FORCE_CLKSLOW | Infra bus DCM force clock slow <ul style="list-style-type: none"> <li>• o: Disable</li> <li>• 1: Enable</li> </ul>                                            |
| 16     |          | RG_BUS_FORCE_CLKOFF  | Infra bus DCM force clock off <ul style="list-style-type: none"> <li>• o: Disable</li> <li>• 1: Enable</li> </ul>                                             |
| 8      |          | RG_BUS_CLKSLOW_EN    | Infra bus DCM clock slow enable <ul style="list-style-type: none"> <li>• o: Disable</li> <li>• 1: Enable</li> </ul>                                           |
| 0      |          | RG_BUS_CLKOFF_EN     | Infra bus DCM clock off enable (turn on at the same time with CLKSLOW_EN) <ul style="list-style-type: none"> <li>• o: Disable</li> <li>• 1: Enable</li> </ul> |

**A21Do110    CM4 DCM  
CON 0****Cortex-M4 domain clock DCM 0****oooooooooo**

| Bit   | 31 | 30 | 29 | 28                | 27 | 26 | 25 | 24 | 23 | 22 | 21          | 20 | 19 | 18 | 17 | 16   |
|-------|----|----|----|-------------------|----|----|----|----|----|----|-------------|----|----|----|----|------|
| Name  |    |    |    |                   |    |    |    |    |    |    |             |    |    |    |    | RG_C |
| Type  |    |    |    |                   |    |    |    |    |    |    |             |    |    |    |    | RW   |
| Reset |    |    |    |                   |    |    |    |    |    |    |             |    |    |    |    | o    |
| Bit   | 15 | 14 | 13 | 12                | 11 | 10 | 9  | 8  | 7  | 6  | 5           | 4  | 3  | 2  | 1  | 0    |
| Name  |    |    |    | RG_CM_DCM_DBC_NUM |    |    |    |    |    |    | RG_CM_SFSEL |    |    |    |    |      |
| Type  |    |    |    | RW                |    |    |    |    |    |    | RW          |    |    |    |    |      |
| Reset |    |    |    | o                 | o  | o  | o  | o  |    |    | o           | o  | o  | o  | o  | o    |

| Bit(s) | Mnemonic | Name             | Description                                                                                                      |
|--------|----------|------------------|------------------------------------------------------------------------------------------------------------------|
| 16     |          | RG_CM_DCM_DBC_EN | CMSYS domain DCM debounce en <ul style="list-style-type: none"> <li>• o: Disable</li> <li>• 1: Enable</li> </ul> |

---

|      |                   |                                                                                                   |
|------|-------------------|---------------------------------------------------------------------------------------------------|
| 12:8 | RG_CM_DCM_DBC_NUM | CMSYS domain DCM debounce number                                                                  |
|      |                   | <ul style="list-style-type: none"> <li>• 0: Disable</li> <li>• 1: Enable</li> </ul>               |
| 5:0  | RG_CM_SFSEL       | CMSYS domain DCM idle divide selection                                                            |
|      |                   | 100000: /1<br>010000: /2<br>001000: /4<br>000100: /8<br>000010: /16<br>000001: /32<br>000000: /64 |

---

| <b>A21D0114 CM4 DCM CON 1</b> |    | <b>Cortex-M4 domain clock DCM 1</b> |    |    |    |    |    |                                  |    |    |    |    |    |    |    |    | <b>oooooooooooo</b>            |  |  |  |
|-------------------------------|----|-------------------------------------|----|----|----|----|----|----------------------------------|----|----|----|----|----|----|----|----|--------------------------------|--|--|--|
| <b>Bit</b>                    | 31 | 30                                  | 29 | 28 | 27 | 26 | 25 | 24                               | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | <b>RG_C_M_FO_RC_E_CL_KO_FF</b> |  |  |  |
| <b>Name</b>                   |    |                                     |    |    |    |    |    | <b>RG_C_M_FO_RC_E_CL_KS_LO_W</b> |    |    |    |    |    |    |    |    | <b>RG_C_M_FO_RC_E_CL_KO_FF</b> |  |  |  |
| <b>Type</b>                   |    |                                     |    |    |    |    |    | RW                               |    |    |    |    |    |    |    |    | RW                             |  |  |  |
| <b>Reset</b>                  |    |                                     |    |    |    |    |    | 0                                |    |    |    |    |    |    |    |    | 0                              |  |  |  |
| <b>Bit</b>                    | 15 | 14                                  | 13 | 12 | 11 | 10 | 9  | 8                                | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |                                |  |  |  |
| <b>Name</b>                   |    |                                     |    |    |    |    |    | <b>RG_C_M_CL_KS_LO_W_EN</b>      |    |    |    |    |    |    |    |    |                                |  |  |  |
| <b>Type</b>                   |    |                                     |    |    |    |    |    | RW                               |    |    |    |    |    |    |    |    |                                |  |  |  |
| <b>Reset</b>                  |    |                                     |    |    |    |    |    | 0                                |    |    |    |    |    |    |    |    |                                |  |  |  |

---

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b>         | <b>Description</b>                                                                  |
|---------------|-----------------|---------------------|-------------------------------------------------------------------------------------|
| 24            |                 | RG_CM_FORCE_CLKSLOW | CMSYS domain DCM force clock slow                                                   |
|               |                 |                     | <ul style="list-style-type: none"> <li>• 0: Disable</li> <li>• 1: Enable</li> </ul> |
| 16            |                 | RG_CM_FORCE_CLKOFF  | CMSYS domain DCM force clock off                                                    |
|               |                 |                     | <ul style="list-style-type: none"> <li>• 0: Disable</li> <li>• 1: Enable</li> </ul> |
| 8             |                 | RG_CM_CLKSLOW_EN    | CMSYS domain DCM clock slow en                                                      |
|               |                 |                     | <ul style="list-style-type: none"> <li>• 0: Disable</li> <li>• 1: Enable</li> </ul> |

---

| <b>A21D0130 SYS FREE DCM CON</b> |    | <b>cm domain free run clock dcm</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    | <b>oooooooooooo20</b> |  |  |  |
|----------------------------------|----|-------------------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|-----------------------|--|--|--|
| <b>Bit</b>                       | 31 | 30                                  | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |                       |  |  |  |

| <b>A21D0130</b> |    | <b>SYS FREE<br/>DCM CON</b> | <b>cm domain free run clock dcm</b> |    |    |    |   |   |   |   |   |   |   |   |   | <b>oooooooooooo</b>     |   |   |   |   |   |
|-----------------|----|-----------------------------|-------------------------------------|----|----|----|---|---|---|---|---|---|---|---|---|-------------------------|---|---|---|---|---|
| <b>Name</b>     |    |                             |                                     |    |    |    |   |   |   |   |   |   |   |   |   |                         |   |   |   |   |   |
| <b>Type</b>     |    |                             |                                     |    |    |    |   |   |   |   |   |   |   |   |   |                         |   |   |   |   |   |
| <b>Reset</b>    |    |                             |                                     |    |    |    |   |   |   |   |   |   |   |   |   |                         |   |   |   |   |   |
| <b>Bit</b>      | 15 | 14                          | 13                                  | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                       |   |   |   |   |   |
| <b>Name</b>     |    |                             |                                     |    |    |    |   |   |   |   |   |   |   |   |   | <b>RG_SYS_FREE_FSEL</b> |   |   |   |   |   |
| <b>Type</b>     |    |                             |                                     |    |    |    |   |   |   |   |   |   |   |   |   | <b>RW</b>               |   |   |   |   |   |
| <b>Reset</b>    |    |                             |                                     |    |    |    |   |   |   |   |   |   |   |   |   | 1                       | 0 | 0 | 0 | 0 | 0 |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b>      | <b>Description</b>                                                                                                                                            |
|---------------|-----------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:0           |                 | RG_SYS_FREE_FSEL | SYS (CMSYS and BUS) domain free run DCM divide selection<br>100000: /1<br>010000: /2<br>001000: /4<br>000100: /8<br>000010: /16<br>000001: /32<br>000000: /64 |

| <b>A21D0140</b> |    | <b>SFC DCM C<br/>ON o</b> | <b>SFC domain clock DCM o</b> |                           |    |    |    |    |    |    |    |    |    |    |    | <b>oooooooooooo</b>       |           |  |  |
|-----------------|----|---------------------------|-------------------------------|---------------------------|----|----|----|----|----|----|----|----|----|----|----|---------------------------|-----------|--|--|
| <b>Bit</b>      | 31 | 30                        | 29                            | 28                        | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                        |           |  |  |
| <b>Name</b>     |    |                           |                               | <b>RG_SFC_DCM_APB_SEL</b> |    |    |    |    |    |    |    |    |    |    |    | <b>RG_SFC_DCM_APB_SEL</b> |           |  |  |
| <b>Type</b>     |    |                           |                               | <b>RW</b>                 |    |    |    |    |    |    |    |    |    |    |    |                           | <b>RW</b> |  |  |
| <b>Reset</b>    |    |                           |                               | 0                         | 0  | 0  | 0  | 0  |    |    |    |    |    |    |    |                           | 0         |  |  |
| <b>Bit</b>      | 15 | 14                        | 13                            | 12                        | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                         |           |  |  |
| <b>Name</b>     |    |                           |                               | <b>RG_SFC_DCM_DBC_NUM</b> |    |    |    |    |    |    |    |    |    |    |    |                           |           |  |  |
| <b>Type</b>     |    |                           |                               | <b>RW</b>                 |    |    |    |    |    |    |    |    |    |    |    |                           |           |  |  |
| <b>Reset</b>    | 0  | 0                         | 0                             | 0                         | 0  | 0  | 0  | 0  |    |    |    |    |    |    |    |                           |           |  |  |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b>        | <b>Description</b>                                                                                                                                                                                        |
|---------------|-----------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 28:24         |                 | RG_SFC_DCM_APB_SEL | Each bit corresponds to the selection of change to activate. <ul style="list-style-type: none"> <li>bit 0: dcm_force_on</li> <li>bit 1: dcm_en</li> <li>bit 2: dbc_en</li> <li>bit 3: dcm_fsel</li> </ul> |
| 16            |                 | RG_SFC_DCM_DBC_EN  | SFC domain DCM debounce enable <ul style="list-style-type: none"> <li>0: Disable</li> <li>1: Enable</li> </ul>                                                                                            |
| 15:8          |                 | RG_SFC_DCM_DBC_NUM | SFC domain DCM debounce number                                                                                                                                                                            |

- 0: Disable
- 1: Enable

| A21D0144 <u>SFC_DCM_C</u> |    | SFC domain clock DCM 1 |    |    |    |    |    |                                                    |    |    |    |    |    |    |    | oooooooooo                                              |  |
|---------------------------|----|------------------------|----|----|----|----|----|----------------------------------------------------|----|----|----|----|----|----|----|---------------------------------------------------------|--|
| Bit                       | 31 | 30                     | 29 | 28 | 27 | 26 | 25 | 24                                                 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                                                      |  |
| Name                      |    |                        |    |    |    |    |    | RG<br>_S<br>FC<br>_D<br>CM<br>_A<br>PB<br>_T<br>OG |    |    |    |    |    |    |    | RG<br>_S<br>FC<br>_F<br>OR<br>CE<br>_C<br>LK<br>OF<br>F |  |
| Type                      |    |                        |    |    |    |    |    | RW                                                 |    |    |    |    |    |    |    | RW                                                      |  |
| Reset                     |    |                        |    |    |    |    |    | o                                                  |    |    |    |    |    |    |    | o                                                       |  |
| Bit                       | 15 | 14                     | 13 | 12 | 11 | 10 | 9  | 8                                                  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                                                       |  |
| Name                      |    |                        |    |    |    |    |    |                                                    |    |    |    |    |    |    |    | RG<br>_S<br>FC<br>_C<br>LK<br>OF<br>F<br>_EN            |  |
| Type                      |    |                        |    |    |    |    |    |                                                    |    |    |    |    |    |    |    | RW                                                      |  |
| Reset                     |    |                        |    |    |    |    |    |                                                    |    |    |    |    |    |    |    | o                                                       |  |

| Bit(s) | Mnemonic | Name                | Description                                                                                                         |
|--------|----------|---------------------|---------------------------------------------------------------------------------------------------------------------|
| 24     |          | RG_SFC_DCM_APB_TOG  | Toggle the bit to activate the change                                                                               |
| 16     |          | RG_SFC_FORCE_CLKOFF | SFC domain DCM force clock off                                                                                      |
| o      |          | RG_SFC_CLKOFF_EN    | <ul style="list-style-type: none"> <li>• 0: Disable</li> <li>• 1: Enable</li> </ul> SFC domain DCM clock off enable |
|        |          |                     | <ul style="list-style-type: none"> <li>• 0: Disable</li> <li>• 1: Enable</li> </ul>                                 |

| A21D0170 <u>CLK_FREQ_SWCH</u> |    | Clock Switch register |    |    |    |    |    |                                             |    |    |    |    |    |    |                                  | oooooooooooo |  |
|-------------------------------|----|-----------------------|----|----|----|----|----|---------------------------------------------|----|----|----|----|----|----|----------------------------------|--------------|--|
| Bit                           | 31 | 30                    | 29 | 28 | 27 | 26 | 25 | 24                                          | 23 | 22 | 21 | 20 | 19 | 18 | 17                               | 16           |  |
| Name                          |    |                       |    |    |    |    |    |                                             |    |    |    |    |    |    |                                  |              |  |
| Type                          |    |                       |    |    |    |    |    |                                             |    |    |    |    |    |    |                                  |              |  |
| Reset                         |    |                       |    |    |    |    |    |                                             |    |    |    |    |    |    |                                  |              |  |
| Bit                           | 15 | 14                    | 13 | 12 | 11 | 10 | 9  | 8                                           | 7  | 6  | 5  | 4  | 3  | 2  | 1                                | 0            |  |
| Name                          |    |                       |    |    |    |    |    | RG<br>_P<br>D<br>_PL<br>LC<br>_K<br>SE<br>L |    |    |    |    |    |    | RG<br>_P<br>LL<br>CK<br>_S<br>EL |              |  |
| Type                          |    |                       |    |    |    |    |    | RW                                          |    |    |    |    |    |    |                                  | RW           |  |

**A21Do170**    **CLK FREQ**  
**SWCH**

**Clock Switch register****00000100**

|              |   |   |
|--------------|---|---|
| <b>Reset</b> | 1 | 0 |
|--------------|---|---|

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b>     | <b>Description</b>                                                                               |
|---------------|-----------------|-----------------|--------------------------------------------------------------------------------------------------|
| 8             |                 | RG_PD_PLLCK_SEL | Set to 1 to switch all PD clocks to PLL clock source instead of 26MHz used for initial power-on. |
| 0             |                 | RG_PLLCK_SEL    | Set to 1 to switch all clocks to PLL clock source instead of 26MHz used for initial power-on.    |

**A21Do30**    **PDN CONDo**  
**0**

**Clock gating control 0****0000FFFF**

| <b>Bit</b>              | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b>             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>PDN_CONDo[31:16]</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>             | RO |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| <b>Bit</b>              | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Name</b>             |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>PDN_CONDo[15:0]</b>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Type</b>             | RO |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b>            | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  | 1  |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b> | <b>Description</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------------|-----------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0          |                 | PDN_CONDo   | Indicate clock on/off status.<br>22 RG_SW_SDIOSLV(CG)<br>21 RG_SW_CRYPTO(CG)<br>20 RG_SW_UART0(CG)<br>19 RG_SW_XTALCTL(CG)<br>18 RG_SW_TRNG(CG)<br>17 RG_SFC_SW(CG)<br>16 RG_SW_CM_SYSROM(CG)<br>13 RG_SW_I2C1(CG)<br>12 RG_SW_I2CO(CG)<br>11 RSV_11<br>10 RG_SW_UART2(CG)<br>9 RG_SW_UART1(CG)<br>8 RG_SW_SDIONMST(CG)<br>7 RG_SW_AUDIO(CG)<br>6 RG_SW_SPIMST(CG)<br>5 RG_SW_SPISLV(CG)<br>4 RG_SW_ASYS(CG)<br>3 RG_SW_SDIONMST_BUS(CG)<br>2 RG_SW_CONN_XO(CG)<br>1 RSV_1<br>0 RG_SW_DMA(CG)<br>0: Clock is turned on<br>1: Clock is gated off |

**A21Do310**    **PDN SETDo**

**Clock gating set 0****00000000**

| <b>Bit</b>  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Name</b> |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**PDN\_SETDo[31:16]**

**A21D0310 PDN\_SETDo****Clock gating set 0****oooooooooooo**

| Type  | WO              |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
|-------|-----------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Reset | 0               | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Bit   | 15              | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| Name  | PDN_SETDo[15:0] |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | WO              |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0               | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |

**Bit(s)****Mnemonic****Name**

Description

31:0                    PDN\_SETDo                    Write 1 to set up clock gating control.

22 RG\_SW\_SDIOSLV(CG)  
 21 RG\_SW\_CRYPTO(CG)  
 20 RG\_SW\_UART0(CG)  
 19 RG\_SW\_XTALCTL(CG)  
 18 RG\_SW\_TRNG(CG)  
 17 RG\_SFC\_SW(CG)  
 16 RG\_SW\_CM\_SYSROM(CG)  
 13 RG\_SW\_I2C1(CG)  
 12 RG\_SW\_I2C0(CG)  
 11 RSV\_11  
 10 RG\_SW\_UART2(CG)  
 9 RG\_SW\_UART1(CG)  
 8 RG\_SW\_SDIMST(CG)  
 7 RG\_SW\_AUDIO(CG)  
 6 RG\_SW\_SPIMST(CG)  
 5 RG\_SW\_SPISLV(CG)  
 4 RG\_SW\_ASYS(CG)  
 3 RG\_SW\_SDIMST\_BUS(CG)  
 2 RG\_SW\_CONN\_XO(CG)  
 1 RSV\_1  
 0 RG\_SW\_DMA(CG)

o: No active  
 1: To turn off clock

**A21D032 PDN\_CLRDo****Clock gating clear 0****oooooooooooo**

| Bit   | 31               | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  | PDN_CLRDo[31:16] |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | WO               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit   | 15               | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | PDN_CLRDo[15:0]  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | WO               |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

**Bit(s)****Mnemonic****Name****Description**

31:0                    PDN\_CLRDo                    Write 1 to clear clock gating control.

22 RG\_SW\_SDIOSLV(CG)  
 21 RG\_SW\_CRYPTO(CG)  
 20 RG\_SW\_UART0(CG)  
 19 RG\_SW\_XTALCTL(CG)  
 18 RG\_SW\_TRNG(CG)

---

17 RG\_SFC\_SW(CG)  
 16 RG\_SW\_CM\_SYSROM(CG)  
 13 RG\_SW\_I2C1(CG)  
 12 RG\_SW\_I2C0(CG)  
 11 RSV\_11  
 10 RG\_SW\_UART2(CG)  
 9 RG\_SW\_UART1(CG)  
 8 RG\_SW\_SDIO(MST)(CG)  
 7 RG\_SW\_AUDIO(CG)  
 6 RG\_SW\_SPI(MST)(CG)  
 5 RG\_SW\_SPI(SLV)(CG)  
 4 RG\_SW\_ASYS(CG)  
 3 RG\_SW\_SDIO(MST)(BUS)(CG)  
 2 RG\_SW\_CONN\_XO(CG)  
 1 RSV\_1  
 o RG\_SW\_DMA(CG)  
 o: No active  
 1: To turn on clock

---

#### 22.2.4. cksys register map

**Module name: cksys Base address: (+A2020000h)**

| Address  | Name                             | Width | Register Functionality                                   |
|----------|----------------------------------|-------|----------------------------------------------------------|
| A2020220 | <u>CKSYS TST_SEL_0</u>           | 32    | <b>Test Clock Selection Register 0</b>                   |
| A2020224 | <u>CKSYS TST_SEL_1</u>           | 32    | <b>Test Clock Selection Register 1</b>                   |
| A2020240 | <u>CKSYS CLK_CFG_0</u>           | 32    | <b>Function Clock Selection Register 0</b>               |
| A2020244 | <u>CKSYS CLK_CFG_1</u>           | 32    | <b>Function Clock Selection Register 1</b>               |
| A2020250 | <u>CKSYS CLK_UPDATE_0</u>        | 32    | <b>Function Clock Selection Update Register 0</b>        |
| A2020254 | <u>CKSYS CLK_UPDATE_1</u>        | 32    | <b>Function Clock Selection Update Register 1</b>        |
| A2020260 | <u>CKSYS CLK_UPDATE_STATUS_0</u> | 32    | <b>Function Clock Selection Update Status Register 0</b> |
| A2020264 | <u>CKSYS CLK_UPDATE_STATUS_1</u> | 32    | <b>Function Clock Selection Update Status Register 1</b> |
| A2020270 | <u>CKSYS CLK_FORCE_ON_0</u>      | 32    | <b>Function Clock Force On Register 0</b>                |
| A2020274 | <u>CKSYS CLK_FORCE_ON_1</u>      | 32    | <b>Function Clock Force On Register 1</b>                |
| A2020280 | <u>CKSYS CLK_DIV_0</u>           | 32    | <b>Clock divider control register 0</b>                  |
| A2020284 | <u>CKSYS CLK_DIV_1</u>           | 32    | <b>Clock divider control register 1</b>                  |
| A2020288 | <u>CKSYS CLK_DIV_2</u>           | 32    | <b>Clock divider control register 2</b>                  |
| A202028C | <u>CKSYS CLK_DIV_3</u>           | 32    | <b>Clock divider control register 3</b>                  |
| A2020290 | <u>CKSYS CLK_DIV_4</u>           | 32    | <b>Clock divider control register 4</b>                  |
| A2020294 | <u>CKSYS CLK_DIV_5</u>           | 32    | <b>Clock divider control register 5</b>                  |
| A20202A0 | <u>CKSYS XTAL_FREQ</u>           | 32    | <b>XTAL frequency control register</b>                   |
| A20202A4 | <u>CKSYS REF_CLK_SEL</u>         | 32    | <b>PLL reference clock selection register</b>            |

| Address  | Name                             | Width | Register Functionality                                                                                                                                                                   |
|----------|----------------------------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A2020400 | <u>PLL_ABIST_FQMTR_CON_0</u>     | 32    | <b>Frequency Meter Control Register 0</b><br>Enables frequency meter and sets parameter.<br>Frequency(TESTED clock) = Frequency(FIXED clock) * FQMTR_DATA[15:0]/FQMTR_WINSET[11:0]       |
| A2020404 | <u>PLL_ABIST_FQMTR_CON_1</u>     | 32    | <b>Frequency Meter Control Register 1</b><br>Selects measured clock of frequency meter                                                                                                   |
| A2020408 | <u>PLL_ABIST_FQMTR_CON_2</u>     | 32    | <b>Frequency Meter Control Register 2</b><br>Selects measured clock of frequency meter                                                                                                   |
| A202040C | <u>PLL_ABIST_FQMTR_DATA_A</u>    | 32    | <b>Frequency Meter Data</b><br>Measurement result of frequency meter.<br>Frequency(TESTED clock) = Frequency(FIXED clock)<br>*{FQMTR_DATA_MSB[7:0], FQMTR_DATA[15:0]}/FQMTR_WINSET[11:0] |
| A2020220 | <u>CKSYS_TST_SEL_0</u>           | 32    | <b>Test Clock Selection Register 0</b>                                                                                                                                                   |
| A2020224 | <u>CKSYS_TST_SEL_1</u>           | 32    | <b>Test Clock Selection Register 1</b>                                                                                                                                                   |
| A2020240 | <u>CKSYS_CLK_CFG_0</u>           | 32    | <b>Function Clock Selection Register 0</b>                                                                                                                                               |
| A2020244 | <u>CKSYS_CLK_CFG_1</u>           | 32    | <b>Function Clock Selection Register 1</b>                                                                                                                                               |
| A2020250 | <u>CKSYS_CLK_UPDATE_0</u>        | 32    | <b>Function Clock Selection Update Register 0</b>                                                                                                                                        |
| A2020254 | <u>CKSYS_CLK_UPDATE_1</u>        | 32    | <b>Function Clock Selection Update Register 1</b>                                                                                                                                        |
| A2020260 | <u>CKSYS_CLK_UPDATE_STATUS_0</u> | 32    | <b>Function Clock Selection Update Status Register 0</b>                                                                                                                                 |
| A2020264 | <u>CKSYS_CLK_UPDATE_STATUS_1</u> | 32    | <b>Function Clock Selection Update Status Register 1</b>                                                                                                                                 |
| A2020270 | <u>CKSYS_CLK_FORCE_ON_0</u>      | 32    | <b>Function Clock Force On Register 0</b>                                                                                                                                                |
| A2020274 | <u>CKSYS_CLK_FORCE_ON_1</u>      | 32    | <b>Function Clock Force On Register 1</b>                                                                                                                                                |
| A2020280 | <u>CKSYS_CLK_DIV_0</u>           | 32    | <b>Clock divider control register 0</b>                                                                                                                                                  |
| A2020284 | <u>CKSYS_CLK_DIV_1</u>           | 32    | <b>Clock divider control register 1</b>                                                                                                                                                  |
| A2020288 | <u>CKSYS_CLK_DIV_2</u>           | 32    | <b>Clock divider control register 2</b>                                                                                                                                                  |
| A202028C | <u>CKSYS_CLK_DIV_3</u>           | 32    | <b>Clock divider control register 3</b>                                                                                                                                                  |
| A2020290 | <u>CKSYS_CLK_DIV_4</u>           | 32    | <b>Clock divider control register 4</b>                                                                                                                                                  |
| A2020294 | <u>CKSYS_CLK_DIV_5</u>           | 32    | <b>Clock divider control register 5</b>                                                                                                                                                  |
| A20202A0 | <u>CKSYS_XTAL_FREQ</u>           | 32    | <b>XTAL frequency control register</b>                                                                                                                                                   |
| A20202A4 | <u>CKSYS_REF_CLK_SEL</u>         | 32    | <b>PLL reference clock selection register</b>                                                                                                                                            |
| A2020400 | <u>PLL_ABIST_FQMTR_CON_0</u>     | 32    | <b>Frequency Meter Control Register 0</b><br>Enables frequency meter and sets parameter.<br>Frequency(TESTED clock) = Frequency(FIXED clock) * FQMTR_DATA[15:0]/FQMTR_WINSET[11:0]       |
| A2020404 | <u>PLL_ABIST_FQMTR_CON_1</u>     | 32    | <b>Frequency Meter Control Register 1</b><br>Selects measured clock of frequency meter                                                                                                   |
| A2020408 | <u>PLL_ABIST_FQMTR_CON_2</u>     | 32    | <b>Frequency Meter Control Register 2</b><br>Selects measured clock of frequency meter                                                                                                   |

| Address  | Name                         | Width | Register Functionality                                                                                                                                                                                                   |
|----------|------------------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A202040C | <u>PLL_ABIST_FQMTR_DAT_A</u> | 32    | <b>Frequency Meter Data</b><br><b>Measurement result of frequency meter.</b><br><b>Frequency(TESTED clock) =</b><br><b>Frequency(FIXED clock)</b><br>$*\{FQMTR\_DATA\_MSB[7:0], FQMTR\_DATA[15:0]\}/FQMTR\_WINSET[11:0]$ |

**A202022 CKSYS TST  
o SEL o Test Clock Selection Register o 00000000**

| Bit          | 31                      | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|-------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Mne</b>   | <u>tst_sel_o[31:16]</u> |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW |
| <b>Type</b>  |                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit          | 15                      | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Mne</b>   | <u>tst_sel_o[15:0]</u>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW |
| <b>Type</b>  |                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Mnemonic  | Name      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------|-----------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | tst_sel_o | tst_sel_o | [0:0] tstclk1_sel o: tclk1;1: tclk4 tstclk1; clock option selection <ul style="list-style-type: none"> <li>• [1:1] tstclk2_sel o: tclk2;1: tclk5 tstclk2; clock option selection</li> <li>• [3:2] fsys_tstsel o: from PLL;1: from tclk3;2: from tstclk1;3: from tstclk2; TST clock source selection</li> <li>• [5:4] fsfc_tstsel o: from PLL;1: from tclk3;2: from tstclk1;3: from tstclk2; TST clock source selection</li> <li>• [7:6] fconn_tstsel o: from PLL;1: from tclk3;2: from tstclk1;3: from tstclk2; TST clock source selection</li> <li>• [9:8] fspimst_tstsel o: from PLL;1: from tclk3;2: from tstclk1;3: from tstclk2; TST clock source selection</li> <li>• [11:10] fxtalctl_tstsel o: from PLL;1: from tclk3;2: from tstclk1;3: from tstclk2; TST clock source selection</li> <li>• [13:12] fsdiomst_tstsel o: from PLL;1: from tclk3;2: from tstclk1;3: from tstclk2; TST clock source selection</li> </ul> |
|        |           |           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|        |           |           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|        |           |           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

**A2020224 CKSYS TST  
SEL 1 Test Clock Selection Register 1 00000000**

| Bit          | 31                      | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|--------------|-------------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| <b>Mne</b>   | <u>tst_sel_1[31:16]</u> |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW |
| <b>Type</b>  |                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| Bit          | 15                      | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| <b>Mne</b>   | <u>tst_sel_1[15:0]</u>  |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW |
| <b>Type</b>  |                         |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| <b>Reset</b> | 0                       | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Mnemonic  | Name      | Description                                                                                                                                  |
|--------|-----------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 31:0   | tst_sel_1 | tst_sel_1 | [4:0] fqmtr_tcksel <ul style="list-style-type: none"> <li>0: 0</li> <li>1: f_fxo_ck</li> <li>2: f_frtc_ck</li> <li>3: clk_pll2_d3</li> </ul> |
|        |           |           |                                                                                                                                              |
|        |           |           |                                                                                                                                              |
|        |           |           |                                                                                                                                              |

4: clk\_pll1\_d2  
 5: f\_fxo\_2m\_ck  
 6: AD\_XO\_BBTOP\_CLK (after test MUX)  
 7: AD\_XO\_CK  
 8: clk\_pll2\_d5  
 9: clk\_pll2\_d15  
 10: clk\_pll1\_d7  
 11: AD\_XPLL\_CLK  
 12: AD\_WF\_BBPLL\_CKMON  
 13: AD\_XO\_BBTOP\_CLK  
 14: 0  
 15: 0  
 16: PAD\_SOC\_CK (for testmode)  
 17: hf\_fsfc\_ck  
 18: hf\_fconn\_ck  
 19: hf\_fsys\_ck  
 20: f\_fspimst\_ck  
 21: f\_fsdiomst\_ck  
 22: f\_fxtaletl\_ck  
 23: bbpll2\_d3\_d8  
 24: bbpll2\_d5\_d4  
 25: bbpll2\_d5\_d8  
 26: bbpll1\_d7\_d2  
 27: xo\_d2  
 28: 0  
 29: 0  
 30: 0  
 31: fixed\_ck  
 [10:8] fqmtr\_fcksel  
 0: f\_fxo\_ck  
 1: f\_frtc\_ck  
 2: PAD\_SOC\_CK (for testmode)  
 3: AD\_XO\_BBTOP\_CLK  
 4: EOSC32K\_CK  
 5: xo\_div\_32k\_ck  
 6: XOSC32K\_CK  
 7: f\_fxtaletl\_ck

| A202024      CKSYS CLK |                | Function Clock Selection Register |    |    |    |    |    |    |              |    |    |    |    |    |    |    |   |
|------------------------|----------------|-----------------------------------|----|----|----|----|----|----|--------------|----|----|----|----|----|----|----|---|
| 0                      | CFG 0          | 00000000                          |    |    |    |    |    |    |              |    |    |    |    |    |    |    |   |
| Bit                    | 31             | 30                                | 29 | 28 | 27 | 26 | 25 | 24 | 23           | 22 | 21 | 20 | 19 | 18 | 17 | 16 |   |
| Mne                    | clk_spimst_sel |                                   |    |    |    |    |    |    | clk_conn_sel |    |    |    |    |    |    |    |   |
| Type                   | RW             |                                   |    |    |    |    |    |    |              |    |    |    |    |    |    |    |   |
| Reset                  | 0              | 0                                 | 0  | 0  | 0  | 0  | 0  | 0  | 0            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 |
| Bit                    | 15             | 14                                | 13 | 12 | 11 | 10 | 9  | 8  | 7            | 6  | 5  | 4  | 3  | 2  | 1  | 0  |   |
| Mne                    | clk_sfc_sel    |                                   |    |    |    |    |    |    | clk_sys_sel  |    |    |    |    |    |    |    |   |
| Type                   | RW             |                                   |    |    |    |    |    |    |              |    |    |    |    |    |    |    |   |
| Reset                  | 0              | 0                                 | 0  | 0  | 0  | 0  | 0  | 0  | 0            | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0 |

| Bit(s) | Mnemonic       | Name           | Description                                                                                                                                                               |
|--------|----------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31:24  | clk_spimst_sel | clk_spimst_sel | Selects f_fspimst_ck clock MUX <ul style="list-style-type: none"> <li>0: xo_ck, 26/20(MHz)</li> <li>1: BBPLL2_D5_D4, 48(MHz)</li> <li>2: BBPLL2_D5_D2, 96(MHz)</li> </ul> |
| 23:16  | clk_conn_sel   | clk_conn_sel   | Selects hf_fconn_ck clock MUX                                                                                                                                             |

|      |             |             |                                                                                                                                                                                                                                                                                                                                                                        |
|------|-------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:8 | clk_sfc_sel | clk_sfc_sel | <ul style="list-style-type: none"> <li>• 0: xo_ck, 26/20(MHz)</li> <li>• 1: BBPLL2_D3, 320(MHz)</li> <li>• 2: BBPLL1_D2, 520(MHz)</li> </ul> <p>Selects hf_fsfc_ck clock MUX</p> <ul style="list-style-type: none"> <li>• 0: xo_ck, 26/20(MHz)</li> <li>• 1: BBPLL2_D3_D4, 80(MHz)</li> <li>• 2: BBPLL2_D15, 64(MHz)</li> <li>• 3: BBPLL1_D7_D2, 74.29(MHz)</li> </ul> |
| 7:0  | clk_sys_sel | clk_sys_sel | <ul style="list-style-type: none"> <li>• 0: xo_ck, 26/20(MHz)</li> <li>• 1: BBPLL2_D5, 192(MHz)</li> <li>• 2: BBPLL2_D5_D2, 96(MHz)</li> <li>• 3: BBPLL1_D7, 148.57(MHz)</li> </ul>                                                                                                                                                                                    |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b>     | <b>Description</b>                                                                                                                                                                 |
|---------------|-----------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:8          | clk_sdiomst_sel | clk_sdiomst_sel | Selects f_sdiomst_ck clock MUX<br><ul style="list-style-type: none"> <li>• 0: xo_ck, 26/20(MHz)</li> <li>• 1: BBPLL2_D5_D8, 24(MHz)</li> <li>• 2: BBPLL2_D5_D4, 48(MHz)</li> </ul> |
| 7:0           | clk_xtactl_sel  | clk_xtactl_sel  | Selects f_xtactl_ck clock MUX<br><ul style="list-style-type: none"> <li>• 0: rtc_ck, 0.032(MHz)</li> <li>• 1: XO_BBTOP_CK, 40/26(MHz)</li> </ul>                                   |

**A2020250 CKSYS CLK UPDATE o**    **Function Clock Selection Update Register o**    **oooooooooo**

|       |  |  |  |  |  |  |    |  |  |  |  |  |  |  |    |
|-------|--|--|--|--|--|--|----|--|--|--|--|--|--|--|----|
| Type  |  |  |  |  |  |  | c  |  |  |  |  |  |  |  | s  |
| Reset |  |  |  |  |  |  | RW |  |  |  |  |  |  |  | RW |
|       |  |  |  |  |  |  | o  |  |  |  |  |  |  |  | o  |

| Bit(s) | Mnemonic   | Name       | Description                                    |
|--------|------------|------------|------------------------------------------------|
| 24     | chg_spimst | chg_spimst | Turns off hf_fspimst_ck<br>1: Enable clock-off |
| 16     | chg_conn   | chg_conn   | Turns off hf_fconn_ck<br>1: Enable clock-off   |
| 8      | chg_sfc    | chg_sfc    | Turns off hf_fsfc_ck<br>1: Enable clock-off    |
| 0      | chg_sys    | chg_sys    | Turns off hf_fsys_ck<br>1: Enable clock-off    |

**A2020254 CKSYS CLK UPDATE 1**    **Function Clock Selection Update Register 1**    **oooooooooo**

|       |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |               |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---------------|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16            |
| Nam e |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |               |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |               |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |               |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0             |
| Nam e |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | chg_sd_iom_st |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW            |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | o             |

| Bit(s) | Mnemonic    | Name        | Description                                 |
|--------|-------------|-------------|---------------------------------------------|
| 0      | chg_sdiomst | chg_sdiomst | Turns off hf_fsys_ck<br>1: Enable clock-off |

**A202026 CKSYS CLK UPDATE S TATUS o**    **Function Clock Selection Update Status Register o**    **oooooooooo**

|       |    |    |    |    |    |    |    |                  |    |    |    |    |    |    |    |              |
|-------|----|----|----|----|----|----|----|------------------|----|----|----|----|----|----|----|--------------|
| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24               | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16           |
| Nam e |    |    |    |    |    |    |    | chg_sp_ims_t_o_k |    |    |    |    |    |    |    | chg_co_nn_ok |
| Type  |    |    |    |    |    |    |    | RO               |    |    |    |    |    |    |    | RO           |
| Reset |    |    |    |    |    |    |    | o                |    |    |    |    |    |    |    | o            |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8                | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0            |
| Nam e |    |    |    |    |    |    |    | chg_sf_c_o_k     |    |    |    |    |    |    |    | chg_sy_s_o_k |
| Type  |    |    |    |    |    |    |    | RO               |    |    |    |    |    |    |    | RO           |
| Reset |    |    |    |    |    |    |    | o                |    |    |    |    |    |    |    | o            |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b>   | <b>Description</b>                               |
|---------------|-----------------|---------------|--------------------------------------------------|
| 24            | chg_spimst_ok   | chg_spimst_ok | Turns off hf_fspimst_ck<br>1: clock change done  |
| 16            | chg_conn_ok     | chg_conn_ok   | Turns off hf_fconn_ck<br>1: clock change done    |
| 8             | chg_sfc_ok      | chg_sfc_ok    | Turns off hf_fsfc_ck<br>1: clock change done     |
| 0             | chg_sys_ok      | chg_sys_ok    | Turns off hf_fsdiomst_ck<br>1: clock change done |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b>    | <b>Description</b>                               |
|---------------|-----------------|----------------|--------------------------------------------------|
| 0             | chg_sdiomst_ok  | chg_sdiomst_ok | Turns off hf_fsdiomst_ck<br>1; clock change done |

---

| Bit(s) | Mnemonic | Name | Description |
|--------|----------|------|-------------|
|--------|----------|------|-------------|

---

---

|    |                     |                     |                                                                                     |
|----|---------------------|---------------------|-------------------------------------------------------------------------------------|
| 24 | clk_spimst_force_on | clk_spimst_force_on | Forces on CSW clock                                                                 |
|    |                     |                     | <ul style="list-style-type: none"> <li>• 0: Disable</li> <li>• 1: Enable</li> </ul> |
| 16 | clk_conn_force_on   | clk_conn_force_on   | Forces on CSW clock                                                                 |
|    |                     |                     | <ul style="list-style-type: none"> <li>• 0: Disable</li> <li>• 1: Enable</li> </ul> |
| 8  | clk_sfc_force_on    | clk_sfc_force_on    | Forces on CSW clock                                                                 |
|    |                     |                     | <ul style="list-style-type: none"> <li>• 0: Disable</li> <li>• 1: Enable</li> </ul> |
| 0  | clk_sys_force_on    | clk_sys_force_on    | Forces on CSW clock                                                                 |
|    |                     |                     | <ul style="list-style-type: none"> <li>• 0: Disable</li> <li>• 1: Enable</li> </ul> |

---

**CKSYS CLK**  
**A2020274    FORCE ON**      **Function Clock Force On Register 1**      **00000001**

1

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                     |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|------------------------|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                        |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                        |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |                        |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                      |
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | clk_sd_iom_st_force_on |
| Type  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | RW                     |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    | 1                      |

---

| Bit(s) | Mnemonic             | Name                 | Description                                                                                             |
|--------|----------------------|----------------------|---------------------------------------------------------------------------------------------------------|
| 0      | clk_sdiomst_force_on | clk_sdiomst_force_on | Forces on CSW clock <ul style="list-style-type: none"> <li>• 0: Disable</li> <li>• 1: Enable</li> </ul> |

---

**A202028    CKSYS CLK**  
**0            DIV 0**      **Clock divider control register 0**      **00000000**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24              | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16              |
|-------|----|----|----|----|----|----|----|-----------------|----|----|----|----|----|----|----|-----------------|
| Name  |    |    |    |    |    |    |    | clk_pl_l1_d7_en |    |    |    |    |    |    |    | clk_pl_l1_d5_en |
| Type  |    |    |    |    |    |    |    |                 |    |    |    |    |    |    |    | RW              |
| Reset |    |    |    |    |    |    |    |                 |    |    |    |    |    |    |    | 0               |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8               | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0               |
| Name  |    |    |    |    |    |    |    | clk_pl_l1       |    |    |    |    |    |    |    | clk_pl_l1       |

**A202028 CKSYS CLK  
o DIV o**
**Clock divider control register o****oooooooooo**

|       |  |  |  |  |  |  |              |  |  |  |  |  |  |  |              |
|-------|--|--|--|--|--|--|--------------|--|--|--|--|--|--|--|--------------|
| Type  |  |  |  |  |  |  | <b>d3_en</b> |  |  |  |  |  |  |  | <b>d2_en</b> |
| Reset |  |  |  |  |  |  | RW           |  |  |  |  |  |  |  | RW           |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b>    | <b>Description</b>                            |
|---------------|-----------------|----------------|-----------------------------------------------|
| 24            | clk_pll1_d7_en  | clk_pll1_d7_en | To enable dividers<br>0: Disable<br>1: Enable |
| 16            | clk_pll1_d5_en  | clk_pll1_d5_en | To enable dividers<br>0: Disable<br>1: Enable |
| 8             | clk_pll1_d3_en  | clk_pll1_d3_en | To enable dividers<br>0: Disable<br>1: Enable |
| 0             | clk_pll1_d2_en  | clk_pll1_d2_en | To enable dividers<br>0: Disable<br>1: Enable |

**A202028 CKSYS CLK  
4 DIV 1**
**Clock divider control register 1****oooooooooo**

|              |    |    |    |    |    |    |    |                        |    |    |    |    |    |    |    |                        |
|--------------|----|----|----|----|----|----|----|------------------------|----|----|----|----|----|----|----|------------------------|
| <b>Bit</b>   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24                     | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                     |
| <b>Name</b>  |    |    |    |    |    |    |    | <b>clk_pl_l2_d7_en</b> |    |    |    |    |    |    |    | <b>clk_pl_l2_d5_en</b> |
| <b>Type</b>  |    |    |    |    |    |    |    | RW                     |    |    |    |    |    |    |    | RW                     |
| <b>Reset</b> |    |    |    |    |    |    |    | 0                      |    |    |    |    |    |    |    | 0                      |
| <b>Bit</b>   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8                      | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                      |
| <b>Name</b>  |    |    |    |    |    |    |    | <b>clk_pl_l2_d3_en</b> |    |    |    |    |    |    |    | <b>clk_pl_l2_d2_en</b> |
| <b>Type</b>  |    |    |    |    |    |    |    | RW                     |    |    |    |    |    |    |    | RW                     |
| <b>Reset</b> |    |    |    |    |    |    |    | 0                      |    |    |    |    |    |    |    | 0                      |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b>    | <b>Description</b>                            |
|---------------|-----------------|----------------|-----------------------------------------------|
| 24            | clk_pll2_d7_en  | clk_pll2_d7_en | To enable dividers<br>0: Disable<br>1: Enable |
| 16            | clk_pll2_d5_en  | clk_pll2_d5_en | To enable dividers<br>0: Disable<br>1: Enable |
| 8             | clk_pll2_d3_en  | clk_pll2_d3_en | To enable dividers<br>0: Disable<br>1: Enable |
| 0             | clk_pll2_d2_en  | clk_pll2_d2_en | To enable dividers<br>0: Disable<br>1: Enable |

**A202028 CKSYS\_CLK**  
**8 DIV 2**
**Clock divider control register 2****oooooooooooo**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24              | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16              |
|-------|----|----|----|----|----|----|----|-----------------|----|----|----|----|----|----|----|-----------------|
| Name  |    |    |    |    |    |    |    | clk_pll2_d15_en |    |    |    |    |    |    |    | clk_pll1_d15_en |
| Type  |    |    |    |    |    |    |    | RW              |    |    |    |    |    |    |    | RW              |
| Reset |    |    |    |    |    |    |    | 0               |    |    |    |    |    |    |    | 0               |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8               | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0               |
| Name  |    |    |    |    |    |    |    | clk_pll2_div_en |    |    |    |    |    |    |    | clk_pll1_div_en |
| Type  |    |    |    |    |    |    |    | RW              |    |    |    |    |    |    |    | RW              |
| Reset |    |    |    |    |    |    |    | 0               |    |    |    |    |    |    |    | 0               |

| Bit(s) | Mnemonic        | Name            | Description                                   |
|--------|-----------------|-----------------|-----------------------------------------------|
| 24     | clk_pll2_d15_en | clk_pll2_d15_en | To enable dividers<br>0: Disable<br>1: Enable |
| 16     | clk_pll1_d15_en | clk_pll1_d15_en | To enable dividers<br>0: Disable<br>1: Enable |
| 8      | clk_pll2_div_en | clk_pll2_div_en | To enable dividers<br>0: Disable<br>1: Enable |
| 0      | clk_pll1_div_en | clk_pll1_div_en | To enable dividers<br>0: Disable<br>1: Enable |

**A202028 CKSYS\_CLK**  
**C DIV 3**
**Clock divider control register 3****oooooooooooo**

| Bit                   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24            | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16               |
|-----------------------|----|----|----|----|----|----|----|---------------|----|----|----|----|----|----|----|------------------|
| <b>cr_32k_div_sel</b> |    |    |    |    |    |    |    |               |    |    |    |    |    |    |    |                  |
| Type                  |    |    |    |    |    |    |    |               |    |    |    |    |    |    |    | RW               |
| Reset                 |    |    |    |    |    |    |    | 0             | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0                |
| Bit                   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8             | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                |
| Name                  |    |    |    |    |    |    |    | cr_32k_div_sw |    |    |    |    |    |    |    | cr_xo_div_32k_en |
| Type                  |    |    |    |    |    |    |    | RW            |    |    |    |    |    |    |    | RW               |
| Reset                 |    |    |    |    |    |    |    | 0             |    |    |    |    |    |    |    | 1                |

| Bit(s) | Mnemonic          | Name              | Description                           |
|--------|-------------------|-------------------|---------------------------------------|
| 26:16  | cr_32k_div_sel    | cr_32k_div_sel    | To select XO divide to 32K ratio      |
| 8      | cr_32k_div_sel_sw | cr_32k_div_sel_sw | To enable software path<br>0: Disable |

---

|   |                  |                  |                    |
|---|------------------|------------------|--------------------|
|   |                  |                  | 1: Enable          |
| 0 | cr_xo_div_32k_en | cr_xo_div_32k_en | To enable dividers |
| 0 |                  | o: Disable       |                    |
|   |                  | 1: Enable        |                    |

---

**A202029 CKSYS CLK  
0 DIV 4 Clock divider control register 4 00000000**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24           | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16              |
|-------|----|----|----|----|----|----|----|--------------|----|----|----|----|----|----|----|-----------------|
| Name  |    |    |    |    |    |    |    |              |    |    |    |    |    |    |    | cr_pll_te_st    |
| Type  |    |    |    |    |    |    |    |              |    |    |    |    |    |    |    | RW              |
| Reset |    |    |    |    |    |    |    |              |    |    |    |    |    |    |    | 0               |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8            | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0               |
| Name  |    |    |    |    |    |    |    | cr_xo_div_en |    |    |    |    |    |    |    | cr_xo_div_en_sw |
| Type  |    |    |    |    |    |    |    | RW           |    |    |    |    |    |    |    | RW              |
| Reset |    |    |    |    |    |    |    | 0            |    |    |    |    |    |    |    | 0               |

---

| Bit(s) | Mnemonic        | Name            | Description                                             |
|--------|-----------------|-----------------|---------------------------------------------------------|
| 16     | cr_pll_test     | cr_pll_test     | To switch the PLL clock to XO clock to test the divider |
| 8      | cr_xo_div_en    | cr_xo_div_en    | To enable dividers                                      |
| 0      |                 | o: Disable      |                                                         |
|        |                 | 1: Enable       |                                                         |
| 0      | cr_xo_div_en_sw | cr_xo_div_en_sw | To enable software path                                 |
|        |                 | o: Disable      |                                                         |
|        |                 | 1: Enable       |                                                         |

---

**A2020294 CKSYS CLK  
DIV 5 Clock divider control register 5 00000001**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24                    | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16               |
|-------|----|----|----|----|----|----|----|-----------------------|----|----|----|----|----|----|----|------------------|
| Name  |    |    |    |    |    |    |    | cr_xo_2m_di_v_cg      |    |    |    |    |    |    |    | cr_xo_2m_div_sel |
| Type  |    |    |    |    |    |    |    | RW                    |    |    |    |    |    |    |    | RW               |
| Reset |    |    |    |    |    |    |    | 0                     |    |    |    | 0  | 0  | 0  | 0  | 0                |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8                     | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                |
| Name  |    |    |    |    |    |    |    | cr_xo_2m_di_v_s_el_sw |    |    |    |    |    |    |    | cr_xo_2m_di_v_en |
| Type  |    |    |    |    |    |    |    | RW                    |    |    |    |    |    |    |    | RW               |
| Reset |    |    |    |    |    |    |    | 0                     |    |    |    |    |    |    |    | 1                |

---

| Bit(s) | Mnemonic | Name | Description |
|--------|----------|------|-------------|
|--------|----------|------|-------------|

---

---

|       |                     |                     |                                                    |
|-------|---------------------|---------------------|----------------------------------------------------|
| 24    | cr_xo_2m_div_chg    | cr_xo_2m_div_chg    | To update divider ratio                            |
| 20:16 | cr_xo_2m_div_sel    | cr_xo_2m_div_sel    | To select f_fxo_ck divide to 2M ratio              |
| 8     | cr_xo_2m_div_sel_sw | cr_xo_2m_div_sel_sw | To enable software path<br>0: Disable<br>1: Enable |
| 0     | cr_xo_2m_div_en     | cr_xo_2m_div_en     | To enable dividers<br>0: Disable<br>1: Enable      |

---

**A20202A CKSYS XTA L FREQ** **xtal frequency control register** **01020200**

| Bit   | 31 | 30 | 29 | 28 | 27           | 26 | 25 | 24           | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16               |
|-------|----|----|----|----|--------------|----|----|--------------|----|----|----|----|----|----|----|------------------|
| Name  |    |    |    |    |              |    |    | f_fxo_is_26m |    |    |    |    |    |    |    | xtal_freq        |
| Type  |    |    |    |    |              |    |    |              | RO |    |    |    |    |    |    | RO               |
| Reset |    |    |    |    |              |    |    | 1            |    |    |    |    | 0  | 0  | 1  | 0                |
| Bit   | 15 | 14 | 13 | 12 | 11           | 10 | 9  | 8            | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0                |
| Name  |    |    |    |    | cr_xtal_freq |    |    |              |    |    |    |    |    |    |    | cr_xtal_fr_eq_sw |
| Type  |    |    |    |    | RW           |    |    |              |    |    |    |    |    |    |    | RW               |
| Reset |    |    |    |    | 0            | 0  | 1  | 0            |    |    |    |    |    |    |    | 0                |

---

| Bit(s) | Mnemonic        | Name            | Description                                                |
|--------|-----------------|-----------------|------------------------------------------------------------|
| 24     | f_fxo_is_26m    | f_fxo_is_26m    | 1'b0: 20MHz<br>1'b1: 26MHz                                 |
| 19:16  | xtal_freq       | xtal_freq       | [3]: reserved<br>[2]: 40MHz<br>[1]: 26MHz<br>[0]: reserved |
| 11:8   | cr_xtal_freq    | cr_xtal_freq    | [3]: reserved<br>[2]: 40MHz<br>[1]: 26MHz<br>[0]: reserved |
| 0      | cr_xtal_freq_sw | cr_xtal_freq_sw | To enable software path<br>0: Disable<br>1: Enable         |

---

**A20202A CKSYS REF CLK SEL** **pll reference clock selection register** **01010001**

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24                  | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16                   |
|------|----|----|----|----|----|----|----|---------------------|----|----|----|----|----|----|----|----------------------|
| Name |    |    |    |    |    |    |    | rg_conn_use_xo_rd_y |    |    |    |    |    |    |    | rg_tm_re_f_cl_k_s_el |
| Type |    |    |    |    |    |    |    | RW                  |    |    |    |    |    |    |    | RW                   |

**A20202A CKSYS REF  
4 CLK SEL**

**pll reference clock selection register**

**01010001**

| Reset |    |    |    |    |    |    | 1 |   |   |   |   |   |   |   |   | 1                    |
|-------|----|----|----|----|----|----|---|---|---|---|---|---|---|---|---|----------------------|
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0                    |
| Name  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | rg_xpll_re_f_clk_sel |
| Type  |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | RW                   |
| Reset |    |    |    |    |    |    |   |   |   |   |   |   |   |   |   | 1                    |

| Bit(s) | Mnemonic            | Name                | Description                                                                                                                          |
|--------|---------------------|---------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| 24     | rg_conn_use_xo_rdy  | rg_conn_use_xo_rdy  | 1'b0: Use the CONNSYS self-generated XO ready signal<br>1'b1: Use the XO ready signal sent from the global clock tree (faster speed) |
| 16     | rg_tm_ref_clk_sel   | rg_tm_ref_clk_sel   | 1'b0: From XTAL<br>1'b1: For PAD                                                                                                     |
| 0      | rg_xpll_ref_clk_sel | rg_xpll_ref_clk_sel | 1'b0: For PAD<br>1'b1: From XTAL                                                                                                     |

**A202040 PLL ABIST  
0 FQMTR CO  
No**

**Frequency Meter Control Register 0**

**oooooooo**

| Bit   | 31                   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----------------------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  |                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  |                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |                      |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Bit   | 15                   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  | PLL_ABIST_FQMTR_CONO |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type  | RW                   |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset | 0                    | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |

| Bit(s) | Mnemonic             | Name                  | Description                                                                                                                                                                                                                                                                  |
|--------|----------------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15:0   | PLL_ABIST_FQMTR_CONO | PLL_ABIST_FQMT R_CONO | [15] FQMTR_EN frequency-meter enable control signal<br>0: Disable<br>1: Enable<br>[14] FQMTR_RST frequency-meter reset control signal<br>0: Normal operations<br>1: Reset<br>[11:0] FQMTR_WINSET frequency-meter measurement window setting (= number of fixed clock cycles) |

**A202040 PLL ABIST  
4 FQMTR CO  
N1**

**Frequency Meter Control Register 1**

**oooooooo**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Reset |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

**A202040**    **PLL\_ABIST**  
**4**            **FQMTR\_CO**  
**N1**

**Frequency Meter Control Register 1****oooooooooo**

| Type  | 15                   | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|-------|----------------------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|---|
| Name  | PLL_ABIST_FQMTR_CON1 |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Type  | RO                   |    |    |    |    |    |   |   |   |   |   |   |   |   |   |   |
| Reset | 0                    | 0  | 0  | 0  | 0  | 0  | 0 | 0 |   |   |   |   |   |   |   |   |

| Bit(s) | Mnemonic          | Name                      | Description                                                                                              |
|--------|-------------------|---------------------------|----------------------------------------------------------------------------------------------------------|
| 15:8   | PLL_ABIST_FQMTR_C | PLL_ABIST_FQMTR_CON1 [15] | FQMTR_BUSY frequency-meter busy status<br>ON1<br>0: FQMTR is ready<br>1: FQMTR is busy<br>[7:0] not used |

**A202040**    **PLL\_ABIST**  
**8**            **FQMTR\_CO**  
**N2**

**Frequency Meter Control Register 2****oooooooooo**

| Bit   | 31 | 30 | 29 | 28 | 27 | 26 | 25  | 24             | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|-------|----|----|----|----|----|----|-----|----------------|----|----|----|----|----|----|----|----|
| Name  |    |    |    |    |    |    |     |                |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    |     |                |    |    |    |    |    |    |    |    |
| Bit   | 15 | 14 | 13 | 12 | 11 | 10 | 9   | 8              | 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
| Name  |    |    |    |    |    |    |     | FQ<br>MT<br>R_ |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    | CL  |                |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    | KD  |                |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    | IV_ |                |    |    |    |    |    |    |    |    |
|       |    |    |    |    |    |    | EN  |                |    |    |    |    |    |    |    |    |
| Type  |    |    |    |    |    |    | RW  |                |    |    |    |    |    |    |    | RW |
| Reset |    |    |    |    |    |    | 0   |                |    |    |    |    |    |    |    | 0  |

| Bit(s) | Mnemonic        | Name            | Description                                                                      |
|--------|-----------------|-----------------|----------------------------------------------------------------------------------|
| 8      | FQMTR_CLKDIV_EN | FQMTR_CLKDIV_EN | FQMTR_CLKDIV_EN Frequency meter clock dividing enable<br>0: disable<br>1: enable |
| 1:0    | FQMTR_CLKDIV    | FQMTR_CLKDIV    | Frequency meter clock dividing ratio<br>0: /2<br>1: /4<br>2: /8<br>3: /16        |

**A202040**    **PLL\_ABIST**  
**C**            **FQMTR\_DAT**  
**A**

**Frequency Meter Data****oooooooooo**

| Bit  | 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 |
|------|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|----|
| Name |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |
| Type |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |    |

| <b>Bit(s)</b> | <b>Mnemonic</b> | <b>Name</b> | <b>Description</b>               |
|---------------|-----------------|-------------|----------------------------------|
| 23:0          | FQMTR_DATA      | FQMTR_DATA  | Frequency meter measurement data |